### 1 日期类型
- 分类:
- date: 2019-12-10
- time: 11:11:11
- datetime: 2019-12-10 11:11:11
- year: 2019
### 2 枚举 与 集合类型
- 分类:
- 枚举enum 多选一
- 集合set 多选一 或 多选多
# 枚举
create table user1(
id int not null,
name varchar(16),
gender enum('male', 'female', 'others')
);
注意:枚举里面有什么数据,就选择什么数据插入即可;没有5.7以上的版本会报错
# 集合
create table user2(
id int not null,
name varchar(16),
gender enum('male', 'female', 'others'),
hobbies set('read', 'sleep', 'play ball', 'run')
);
# 多选一
insert into user2 values(1, 'tank', 'male', 'read');
# 多选多
注意: read,sleep必须连着写,若不连在一起,则无法插入数据
insert into user2 values(3, 'sean', 'female', 'read,sleep');
### 4 约束条件
约束条件就是,对于数据库表插入数据时加以约束限制。
- primary key (pk)
# 非常重要,主要是用于快速定位到该表中的某一条数据
# 一般主键,用id来表示,因为以后的每张表都必须要有id标识该字段为该表的 "主键" ,主键可以是唯一的表示记录
# 联合主键: 多个字段联合起来作为一个主键,本质上还是一个主键
# 强调: 必须注意
1.一张表必须只有一个主键,如果没有设置主键,会从上到下搜索,直到遇到 "第一个" 非空 且 唯一 的字段自动设置为主键。
- not null + unqiue ---》 设置为主键
2.如果表没有指定任何可以设置主键的字段,那innodb会采用自己默认的一个隐藏关键字作为主键,隐藏意味着查询你的时候通过这个加速查询。
索引: 类似于书的目录, 没有主键就相当于一页一页翻着查询
3.一张表中通常都应该有一个id字段,并且通常将id字段作为主键。
- foreign key (fk)
#标识该字段为该表的 "外键", 用于把当前的表与另一张表绑定关系
- not null
#标识该字段不能为空
- unique key (uk)
#标识该字段的值是唯一的。
# 该约束的作用是,若一张表中插入了该字段已存在的值,则无法插入。
- auto_increment:
#标识该字段的值自动增长 (整数类型,并且为主键)
# 每插入一条数据时,都会让该字段,自动+1,一般我们将表中的id字段,设置为自增,该字段从1开始
- default
#为该字段设置默认值,
#id name sex(default 'male')
- unsigned
#无正负符号
- zerofill
#使用0填充
# 补充:
delete from user10;
# delete删除表的记录或者指定记录,但id不会重置为0
# 删除某一条记录
delete from user10 where id='4';
# 若想要清空id重置为0,可使用truncate user10;