创建表完整的语法:
create table 表名(
字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度) 约束条件],
字段名3 类型[(宽度) 约束条件]
);
注意事项:
1. 在同一张表中,字段名不能相同
2. 宽度和约束条件可选,字段名和类型是必须的
3. 最后一个字段后不能加逗号!
宽度:对存储数据的限制。
例如:新建一个表,create table t1(name char); char类型默认的宽度为1,此时向表格插入数据,Insert into t1 values('jason'); 此时会有两种可能!
严格模式 (STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION)
非严格模式
报错,因为插入的数据宽度超过了默认宽度1
插入成功,但插入数据的结果只有 j ,只显示一位。
在MySQL中有很多中的模式(mode),例如存储数据时,可选择严格模式和非严格模式,选择两种模式存储数据的效果区别如上图;怎样查询此时MySQL使用什么模式:show variables like '%mode%'; 百分号是任意匹配的意思。
此时在严格模式下,我们想要成功将数据插入,就只能选择更改数据的宽度;alter table t1 motify name char(15); 再次插入之前的数据;Insert into t1 values('jason');插入成功。
设置严格模式
set session:当前窗口下有效
set global:全局有效,终生受用!
set global sql_mode = "STRICT_TRANS_TABLES";
# 设置完成后需要退出客户端,重新登录客户端即可,不需要重启服务端
初识约束条件:
null 与 nut null
create table t1(id int,name char not null); # name 数据类型为 char 并且约束条件为 不能为空null;
insert into t1 values(1,'j'); # 正常存储
insert into t1 values(2,null); # 报错
总结:数据类型与约束条件之间的关系,字段类型限制的是存储数据的类型,约束条件是基于字段类型之上的附加的额外限制。
1 数据类型
整型与浮点型
如上图向 t1 插入数据的操作,char 与 varchar 数据类型 在默认模式下,select * from t1; 是看不出差别的,必须使用语句:select char_length(name) from t1; 的方式才能准求查出插入数据的长度;
另外也可以选择修改模式来查看:set global sql-mode='strict_trans_tables,PAD_CHAR_TO_FULL_LENGTH';
char vs varchar
char
varchar
优点:存取速度快,简单粗暴。
缺点:浪费空间
优点:节省空间
缺点:需要自动为数据制作报头,所以存取速度较慢。
枚举与集合
日期类型
枚举(enum):多选一
集合(set):多选多,虽然是多选多但是你可以只选一个
date 年月日
time 时分秒
datetime 年月日时分秒
year 年
create table t15(
id int,
birth date,
class_time time,
reg_time datetime,
yy year
);
insert into t15 values(1,"2000-01-21","11:11:11","2019-01-21 11:11:11","2019");
create table t16(
id int,
name char(6),
gender enum('male','female','others')
);
insert into t16 values(1,'egon','xxx');
create table t17(
id int,
name char(6),
gender enum('male','female','others'),
hobby set('read','DJ','DBJ','run')
);
insert into t17 values(1,'tank','male',"read,DBJ,DJ");
2 约束条件
PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录
FOREIGN KEY (FK) 标识该字段为该表的外键
NOT NULL 标识该字段不能为空
UNIQUE KEY (UK) 标识该字段的值是唯一的
AUTO_INCREMENT 标识该字段的值自动增长(整数类型,而且为主键)
DEFAULT 为该字段设置默认值
UNSIGNED 无符号
ZEROFILL 使用0填充
not null+default
create table user(
id int,
name char(16)
);
insert into user values(1,null) #可以修改
alter table user modify name char(16) notnull;
insert into user(name,id) values(null,2); #报错 插入数据可以在表名后面指定插入数据对应的字段
create table student(
id int,
name char(16) notnull,
gender enum('male','female','others') default 'male')
insert into student(id,name) values(1,'jason') #成功
unique
#单列唯一
create table user1(
id int unique,
name char(16)
);
insert into user1 values(1,'jason'),(1,'egon') #报错
insert into user1 values(1,'jason'),(2,'egon') #成功
#联合唯一
create table server(
id int,
ip char(16),
port int,
unique(ip,port)
)
insert into server values(1,'127.0.0.1',8080);
insert into server values(2,'127.0.0.1',8080); #报错
insert into server values(1,'127.0.0.1',8081);
primary key+auto_increment
#单从约束角度来说primary key就等价于not null unique
create table t11(id int primary key);
desc t11;
insert into t11 values(1),(1); #报错
insert into t11 values(1),(2);#除了约束之外,它还是innodb引擎组织数据的依据,提升查询效率
"""强调:
1.一张表中必须有且只有一个主键,如果你没有设置主键,那么会从上到下搜索直到遇到一个非空且唯一的字段自动将其设置为主键"""create table t12(
id int,
name char(16),
age intnotnull unique,
addr char(16) notnull unique
)engine=innodb;
desc t12;"""2.如果表里面没有指定任何的可以设置为主键的字段,那么innodb会采用自己默认的一个隐藏字段作为主键,隐藏意味着你在查询的时候无法根据这个主键字段加速查询了
索引:类似于书的目录,没有主键就相当于一页一页翻着查
3.一张表中通常都应该有一个id字段,并且通常将改id字段作成主键"""
#联合主键:多个字段联合起来作为表的一个主键,本质还是一个主键
create table t18(
ip char(16),
port int,
primary key(ip,port)
);
desc t18;#主键id作为数据的编号,每次最好能自动递增
create table t13(
id int primary key auto_increment,
name char(16)
);
insert into t13('jason'),('jason'),('jason'); #id字段自动从1开始递增#注意:auto_increment通常都是加在主键上,并且只能给设置为key的字段加
auto_increment:自增
create table t27(
id int primary key auto_increment,
name char(16)
);#联合主键
create table t28(
ip char(16),
port int,
primary key(ip,port)
);
desc t28;