数值型
整数
Tinyint(1字节),smallint(2),mediumint(3),int/integer(4),bigint(8)
特点
- 如果不设置无符号有符号默认有符号,如果想设置无符号,需要添加unsigned关键字。
- 如果插入的数值超出了整型的返回,会报out of range 异常,并插入临界值。
- 如果不设置长度,会默认长度。长度代表了显示的最大宽度,如果不够可以用zerofill填充
小数
浮点数float(M,D) ,double(M,D)
定点数dec(M,D) ,decimal(M,D)
特点
- M:小数前+小数后的总位数
- D:小数部位
- 如果超过范围,则插入临界值
- M,D都可以省略
- 如果是定点数decimal/dec,则M默认为10,D默认为0
- 如果是浮点数float/double,则会根据插入的数值的精度来决定精度
- 定点数的精确度较高,如果要求插入数值的精度较高 如货币运算等。
- 所选择的类型越简单越好,能保存数值的类型越小越好。
字符型
较短的文本
char(0 ~ 255),varchar(0 ~ 65535)
类型 | 写法 | M的意思 | 特点 | 空间的耗费 | 效率 |
---|---|---|---|---|---|
Char | char(M) | 大的字符数,可以省略,默认为1 | 固定长度的字符 | 比较耗费 | 高 |
Varchar | varchar(M) | 最大的字符数,不可省略 | 可变长度的字符 | 比较节省 | 低 |
二进制文本
Binary /varbinary类型类似char,varchar,但是包含二进制字符串而不包含非二进制字符串
较长的文本
text,blob(较长的二进制数据)
枚举类型
enum类型
枚举类型,要求插入的值必须是设定的值中的一个
Create table tab_char(
C1 enum(‘a’,’v’,’b’)
)
Insert into tab_char values (‘a’);
set类型
与enum类似,区别是一次可以选取多个成员,enum只能选一个
Create table tab_char1(
C2 set(‘a’,’c’,’we’,’tt’)
)
Insert into tab_char2 values(‘a,we’);
日期型
- Date日期
- Datetime日期和时间
- Timestamp时间戳
- Time时间
- Year年
datetime和timestamp的区别
create table time1(
dt datetime,
ts timestamp
);
insert into time1 values (now(),now());#插入现在的时间
select * from time1;
此时二者时间一致
set time_zone = '+9:00';#修改时区
select * from time1;
此时时间不同,timestamp发生变化
类型 | 字节 | 范围 | 时区影响 |
---|---|---|---|
Datetime | 8 | 1000-9999 | 不 |
Timestamp | 4 | 1970-2038 | 受 |