本文最后更新于 2024年12月5日
1.库操作
1.1 创建数据库
1.2 创建数据库,如果存在
1.3 切换到某个数据库
1.4 更改库字符集
1.5 删除数据库
2.数据类型
2.1 整形
整形 TINYINT
SMALLINT
MEDIUMINT
INT(INTEGER)
BIGINT
,对于整形,长度由范围决定,设置的长度用来补零,但必须在建立字段时搭配zerofill,一旦zerofill,默认为无符号,如果不设置无符号,默认是有符号,如果插入数值超出范围,系统会警告,默认插入临界值。
2.2 浮点数
浮点型小数 float(m,d)
double(m,d)
定点型小数 DECIMAL(m,d)
,精度高,最大取值范围与double相同,m 整数部分和小数部分合起来的位数,d 小数点后保留位数,超出范围默认是临界值
2.3 字符型
短文本char
VARCHAR
,长文本text
CHAR(m)
,m指最大字符数, 固定长度字符,开的空间与长度有关 ,耗费空间,效率高,可以省略m, m默认是1。
VARCHAR(m)
m指最大字符数, 可变长度的字符,开的空间与实际占用有关,节省空间,效率低,不能省略m。
2.4 枚举型
enum('c','b')
掺入的值不在枚举内,默认是空,不区分大小写
2.5 SET
一次可以插入多个值,不区分大小写
2.6 日期值
必须用单引号引起,每个类型作用范围不同
date
1000-01-01 - 9999-12-31
time
838:59:59
datetime
1000-01-01 - 9999-12-31
year
1901 - 2155
TIMESTAMP
1970 - 2038年某一时刻,受时区影响,更能反应实际日期,与MySQL版本和sqlmode关系很大
3.表操作
3.1 创建表
3.2 查看表描述
3.3 修改列名 类型
3.4 修改类约束 类型
3.5 添加新列
3.6 删除列
3.7 修改表名
3.8 删除表
3.9 复制
仅仅复制结构
复制结构和数据
条件复制
复制部分列
复制部分列,不要数据,使用恒不成立
4.约束
6种约束
- NOT NULL (非空约束): 确保列不能有
NULL
值。常用于必须填写的字段。
- DEFAULT (默认值约束): 如果插入数据时未指定该列的值,则使用默认值填充。
- PRIMARY KEY (主键约束): 保证字段值的唯一性和非空,常用于唯一标识表中每一行的字段。
- UNIQUE (唯一约束): 确保列中的值唯一,但可以有
NULL
值。
- CHECK (检查约束): 验证字段的值是否符合指定条件,但 MySQL 并不支持
CHECK
约束。
- FOREIGN KEY (外键约束): 设定两个表之间的关系,确保该字段的值必须来自于主表的关联列。
表级与列级约束:
- 表级约束: 可以在创建表时定义,除
NOT NULL
和 DEFAULT
之外的所有约束都支持。
- 列级约束: 语法上支持所有约束,但 MySQL 中外键在列级定义时可能无法有效执行(需要在表级定义才能生效)。
4.1 主键
添加主键
主键和唯一的对比
都可以保证唯一,主键不能为空,每个表只能有1个,可以两个列自合一起,唯一允许为空,一个表可以有多个,不能多个为空,可以两个列自合一起。
外键,从表设置外键关系,数据类型一致或兼容,主表被关联列必须是一个key,一般是主键或唯一,插入数据时,先插入主表在插入从表,删除数据,先删除从表,再删除主表。
4.2 非空
4.3 唯一
添加唯一
4.4 外键
添加外键
添加外键 名字
4.5删除约束
删除非空
不添加条件,就会删除默认约束
删除主键
先查到,在删除唯一约束
删除外键
4.6标识列
限制某个字段,又叫自增长列,默认从1开始,必须是一个key,同一张表标识列只能有一个,只能是数值类型
步长auto_increment_increment 起始值auto_increment_offset,mysql 可以设置步长,但是不能设置起始值
设置删除标识列