MySQL基础复习与整理---DDL数据定义语言---常见的数据类型

数值型

整数

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的意思特点空间的耗费效率
Charchar(M)大的字符数,可以省略,默认为1固定长度的字符比较耗费
Varcharvarchar(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发生变化

类型字节范围时区影响
Datetime81000-9999
Timestamp41970-2038
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值