MySQL的数据类型

要想做好数据库就得想认识数据类型,只要对数据类型熟悉了才能更好地制作数据库,设计MySQL表结构的时候,有很多数据类型供我们选择,下面我来介绍下MySQL的数据类型!
首先我来说说整数类型:整数类型有可选的unsigned属性,表示不允许负值,这可以使正数的上限提高一倍(还多1)。有符号 和无符号类型使用相同的存储空间,并且具有相同的性能,因此可以根据实际情况选择合适的类型。比较常用的整数数据类型有:tinyint 1字节、smallint 2字节、mediumint 3字节、int 4字节、bigint 8字节,我们来看看它们的用法,最常见的还是tinyint类型(用法如图所示):
在这里插入图片描述

下面我就来说说实数类型:实数类型中DECIMAL类型最多允许65个数字,表示为DECIMAL(M,D)的格式。例如DECIMAL(5,2)表示最多保存5个 数字,其中2个是小数,表示的范围在-999.99 到 999.99之间。如果小数位数D为0,则DECIMAL值不包含小数点或小数部分。FLOAT和DOUBLE类型只能使用标准的浮点运算进行近似运算,例如金额计算,则 需要使用DECIMAL类型。(实数类型如图所示)
在这里插入图片描述

接下来就是字符串类型:char类型是定长的,很适合存储很短的字符串,或者所有的值都接近同一个长度,例如,char非常适合存储密码的 MD5的值,因为这是一个定长的长度。对于经常变动的数据,char也比varchar更好,因为定长的 char类型不容易产生碎片。 对于非常短的列,char比varchar在存储空间上也更有优势,例如用char(1)来存储只有Y和N的值,如果采用单字节字符集只需1个字节,但varchar(1)却需要2个字节,因为还需要一个记录长度的额外字节。varchar用于存储可变长的字符串,它比定长类型更节省空间。varchar需要使用1或2个额外字节记 录字符串的长度:如果列的最大长度小于或等于255字节,则只使用1个字节表示,如果列长度大于255 字节,则需要使用2个字节表示长度。在字符串类型中就这两个类型用的比较频繁。(常用字符串类型如图所示)
在这里插入图片描述

这然后就是日期与时间类型:DATETIME使用8个字节的存储空间,和时区无关。TIMESTAMP使用4个字节的存储空间,显示的时间依赖时区,保存了从1970年1月1号午夜(格林尼治标 准时间)以来的秒数,它和unix的时间戳相同。TIMESTAMP只能表示从1970年到2038年。如果插入和更新数据时没有指定TIMESTAMP的值,MySQL会默认的更新TIMESTAMP的值当前系统时间。(常用日期与时间类型如图所示)
在这里插入图片描述

最后这个就是位数类型:BIT(1)定义一个包含1个位的数据,BIT(2)包含2个位,以此类推,最大长度为64个位。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值