MySQL基础知识点

一、数据类型
1、整型(xxxint)
tinyint(m) 1个字节表示(-128~127)
smallint(m) 2个字节表示(-32768~32767)
mediumint(m) 3个字节表示(-8388608~8388607)
int(m) 4个字节表示(-2147483648~2147483647)
bigint(m) 8个字节表示(±9.22*10的18次方)

m表示最大显示宽度
2、浮点型(float和double)
float(m,d) 单精度浮点型,8位精度(4字节),m是十进制数字的总个数,d是小数点后面的数字个数
double(m,d) 双精度浮点型,16位精度(8字节)

参数m只影响显示效果,不影响精度,d却不同,会影响到精度。
3、定点数(decimal)
decimal(m,d)定点类型。 浮点型在数据库中存放的是近似值,而定点类型在数据库中存放的是精确值。参数m是定点类型数字的最大个数(精度),范围为065,d为小数点右侧数字的个数,范围为030,但不得超过m。对定点数的计算能精确到65位数字。
4、字符串(char,varchar,xxxtext)
char(n) 固定长度的字符串,最多255个字符
varchar(n) 固定长度的字符串,最多65535个字符
tinytext 可变长度字符串,最多255个字符
text 可变长度字符串,最多65535个字符
mediumtext 可变长度字符串,最多2的24次方-1个字符
longtext 可变长度字符串,最多2的32次方-1个字符

n为存入位数
5、二进制数据(xxxBlob)
xxxBlob和xxxtext是对应的,不过存储方式不同,xxxtext是以文本方式存储的,如果存储英文的话区分大小写,而xxxBlob是以二进制方式存储的不区分大小写。xxxBlob存储的数据只能整体读出。xxxtext可以指定字符集,xxxBlob不用指定字符集。
6、日期时间类型
date 日期'2014-10-14'
time 时间'14:47:56'
datetime 日期时间'2014-10-14 14:47:56'
timestamp 不固定

timestamp比较特殊,如果定义一个字段的类型为timestamp,这个字段的时间会在其他字段修改的时候自动刷新。所以这个数据类型的字段可以存放这条记录最后被修改的时间,而不是真正来存放时间。
7、数据类型的属性
NULL 数据列可包含NULL值
NOT NULL 数据列不允许包含NULL值
DEFAULT xxx 默认值,如果插入记录的时候没有指定值,将取这个默认值
PRIMARY KEY 主键
AUTO_INCREMENT 递增,如果插入记录的时候没有指定值,则在上一条记录的值上加1,仅适用于整型
UNSIGNED 无符号
CHARACTER SET name 指定一个字符集

二、基本SQL语句
SQL全称:结构化查询语言(Structured Query Language)
1、MySQL命令行客户端命令
---登录MySQL数据库
mysql -u root-p
password
---查看数据库
show databases
---使用数据库
use 数据库名
---查看当前数据库表
2、数据定义语言(DDL)
---创建数据库
create database 数据库名;
---创建表
create table 表名(字段1,字段2,字段3,…);
例子:
create table teacher(
sid int(11) primary key auto_increment,
name varchar(20),
gender char(1),
age int(2),
birth date);
---查看表结构
desc 表名;
---删除表
drop table 表名;
//该语句会删除该表所有的记录及表结构
---修改表的结构
alter table 表名add columnname varchar(10); ---添加表列
alter table 表名 renamename; ---修改表名
alter table 表名 drop columnname; ---删除表列
alter table 表名 modifyaddress char(10); ---修改表列类型(修改数据类型)
alter table 表名 change address address1 char(40); ---修改表列类型(修改字段名和数据类型)
alter table 表名 change column address address1 varchar(30); ---修改表列名(与上个一样,多了column)

========================================
主键,用来唯一代表一条记录的字段(主键值必须是唯一)

3、数据操作语言(DML)
---添加数据
insert into 表名(字段1,字段2,字段3,…)values(value1,value2,value3,…);
(表名后可以不加括号及字段,但是在values中要将所有的value按对应的顺序输入)
---修改数据
update 表名set 字段名='值',字段名='值',字段名='值'where 字段名='值';
---删除数据
delete from 表名;
---删除ID为1的记录
delete from 表名where id=1;

4、数据查询语言(DRL)
---查询指定字段、位置的信息
select 字段1,字段2,字段3,…from 表名where 字段=值; (其他判断符也可)
select 字段1,字段2,字段3,…from 表名where 字段=值 and 字段=值; (其他判断符也可)
select 字段1,字段2,字段3,…from 表名where 字段=值 or 字段=值; (其他判断符也可)
---模糊查询
select 字段1,字段2,字段3,… from 表名 where 字段 like 值;
例子:
select * from teacherwhere name like '%s';
//查询字段name里以s结尾的数据
select from teacher where name like 's%';
//查询字段name里以s开头的数据
select * from teacher
where* name like '%s%';
//查询字段name里有s出现的数据
---查询并排序
select 字段1,字段2,字段3,…from 表名where 字段=值 order by 字段 asc; //升序 可以不写asc,默认为升序
select 字段1,字段2,字段3,…from 表名** where** 字段=值** order by** 字段desc; //降序
---多条件排序
select 字段1,字段2,字段3,…from 表名where 字段=值 order by 字段 asc,字段 desc;
---分组查询
** select** 字段 函数 from 表名group by 字段;
例子:
select gender,count(gender)from teacher group by gender;
//按gender分组并计数
select gender,count(gender)
from
teacher group by gender having gender='m';
//按gender分组并统计值为m的个数,having在实际应用中应用不太多,例如本例,可以用
select
gender,count(gender)from teacher where gender='m';代替。
---查询值是否为null的信息
select * from 表名where 字段is (not) null;
========================================
在没有表被引用的情况下,只允许指定DUAL作为一个假的表名
select count(字段)as 别名 from 表名 as 别名; //as可省略
select count(字段) as 别名 from 表名 as 别名; //as可省略
select 别名.字段 别名.字段 from 表名 as 别名; //as可省略
select 字段1,字段2,字段3,…from teacherlimit f,n;
//查询前n个信息 f表示起始位置 n表示查询信息的个数
5、事务控制语言(TCL)
事务是访问并可能更新数据库中各种数据项的一个程序执行单元。在关系数据库中,一个事务可以是一条SQL语句,一组SQL语句或整个程序。事务应该具有4个属性:原子性(atomicity)、一致性(consistency)、隔离性(isolation)、持续性(durability)。事务就是对数据库的多步操作,要么一起成功,要么一起失败。
---设置默认事务提交方式
** set autocommit=false//设置事务提交方式为"手动提交"
** set autocommit=true
//设置事务提交方式为"自动提交"
=======================================
commit; //手动提交事务
rollback; //回滚事务
savepointpoint2
;
//保存还原点
rollback to point2; //回滚到point2还原点
学长博客原文http://blog.csdn.net/cc65431362/article/details/40076175
很久以前学过,后来很少敲MySQL命令行也就忘了,不过还是要记着这些基础操作。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,817评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,329评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,354评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,498评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,600评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,829评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,979评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,722评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,189评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,519评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,654评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,329评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,940评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,762评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,993评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,382评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,543评论 2 349

推荐阅读更多精彩内容