MySQL——数据类型
一、常见的数据类型及分类https://i-blog.csdnimg.cn/direct/56b29325be544f9f9eb24f63aa264ef4.png
其中上述的数值类型包罗了整形和浮点型,文本、二进制类型主要是字符串类型。
[*]整数类型(Integer Types):
[*]TINYINT:范围为-128到127或0到255(无符号),用于存储较小的整数值,如存储性别或状态信息。
[*]SMALLINT:范围为-32768到32767或0到65535(无符号),用于存储较小的整数值,如存储年岁或计数值。
[*]MEDIUMINT:范围为-8388608到8388607或0到16777215(无符号),适用于中等大小的整数数值存储。
[*]INT:范围为-2147483648到2147483647或0到4294967295(无符号),适用于一样平常整数值存储。
[*]BIGINT:用于存储大整数值,如存储ID或计数值。
[*]浮点数类型(Floating-Point Types):
[*]FLOAT:用于存储单精度浮点数,约占用4个字节的空间。
[*]DOUBLE:用于存储双精度浮点数,约占用8个字节的空间。
[*]DECIMAL:用于精确的十进制数值存储,适用于货币或其他需要精确计算的场景。
[*]日期与时间类型(Date and Time Types):
[*]DATE:用于存储日期,格式为’YYYY-MM-DD’,如’2000-01-01’。
[*]TIME:用于存储时间,格式为’HH:MM:SS’,如‘18:30:00’。
[*]DATETIME:用于存储日期和时间,格式为’YYYY-MM-DDHH:MM:SS’,如’2000-01-0118:30:00’。
[*]字符串类型(String Types):
[*]CHAR:用于存储固定长度的字符串,如CHAR(10)可以存储长度为10的字符串。
[*]VARCHAR:用于存储可变长度的字符串,如VARCHAR(255)可以存储长度为最大255的字符串。
[*]TEXT:用于存储较长的文本数据,比方文章内容或备注信息。
[*]枚举和聚集类型:
[*]枚举(ENUM)类型:枚举类型答应你从一组预界说的选项中选择一个单独的值。在创建表结构时,你可以指定枚举类型的字段答应的值列表。
[*]聚集(SET)类型:聚集类型答应你从一组预界说的选项中选择多个值,这些值之间用逗号分隔。与枚举类型差异,聚集类型答应选择多个选项,而不但限于一项。
[*]其他类型:
[*]BOOLEAN:在MySQL中没有专门的BOLLEAN类型,通常使用TINTINT(1)来表现bool值,0表现false,1表现true。
二、数值类型
2.1 整型
整型包括以下几种:
https://i-blog.csdnimg.cn/direct/c73ae9ae1ceb4fb68ba6bc66a265ffab.png
它们最根本的区别就是所占用的空间大小差异,也因此导致了可以或许存储的数据范围差异。
2.1.1 tinyint
先来测试一下tinyint的取值范围。
https://i-blog.csdnimg.cn/direct/f4aeb2adb851454983546aa443886363.png
我们实验插入一些数据。
https://i-blog.csdnimg.cn/direct/4381bc6eae484d57b1c32d4f502a6c96.png
在插入合法的范围内是可以或许正常举行插入的,但是一旦凌驾tinyint的取值范围,就会不让插入了,而且当插入的数据不是整型时,也是不让插入。
在C/C++中,int tmp = 'a’最多会发出提醒,并不会报错,本质上发生了隐式类型转换。char a = 200也不会报错,会发生截断。即使你存储的数据超出了指定类型的取值范围,也并不会报错,而是发出警告并且存储溢出后举行调整的值。
在数据库中并不想C/C++那样,而是有着严酷的要求。**mysql的数据类型中,符合条件才会让你操作,不符合条件直接不让操作。**在mysql的数据类型中,除了可以或许满足各种应用场景,还有一个特别重要的用途:数据类型本质就是一种约束!约束就是强制必须按照规则去做,约束的就是使用者,倒逼使用者,必须遵守规则!
我们再来简单测试一下无符号的tinyint。
https://i-blog.csdnimg.cn/direct/9ee910f22a4e4708bc07ea9fc2a28f82.png
我们实验向tmp1列中插入一些数据,如下图:
https://i-blog.csdnimg.cn/direct/ec63518e501b4e5e8e66cc6f0e1f1a2d.png
我们在检察表t1的数据时,发现有NULL。那么NULL和空字符串’ ‘是一样的吗?答案是不一样的。NULL和空字符串’ '代表这差异的含义:
[*]NULL:在数据库中表现缺少值或未知值。当一个字段的值未知大概不适用时,可以使用NULL来表现。NULL不即是任何其他值,包括空字符串。
[*]空字符串’ ':表现一个空的字符串值。当一个字段需要有值,但是没有具体数值或字符时,可以使用空字符串来表现。空字符串是一个有效的值。
在mysql中,字符串可用单引号’ ‘来引用,也可以使用双引号" "来引用。一样平常情况下在mysql中都是用单引号’ '的。
2.1.2 bit
bit类型也是一种数据类型。bit类型是用于存储二进制数字的数据类型。它可以用来表现位值为0或1的数值,比如开关状态、标记位等。
https://i-blog.csdnimg.cn/direct/5931a132886b401c9357a6f106de7645.png
如上图,我们创建了一个t2表。其中包罗了列a,数据类型为int;列b,数据类型为bit(10)。括号内的10的意思就是我们指定有几个比特位。那么b的大小是10个比特位。我们再来测试一下,如下图:
https://i-blog.csdnimg.cn/direct/538c82c10409479e95358e7c437d7935.png
确实能欧插入乐成。10个bit可以或许存储的数据范围是0~1023。确实正如上图所示。我们再来检察一下表中的数据。如下图:
https://i-blog.csdnimg.cn/direct/9cb06e7518104d9f84b165593b0730f1.png
怎么表中存储的并不是我们所插入的数据呢?存储是按照我们所插入的数据举行存储的,但是bit类型在显示时,是按照ASCII码对应的值举行显示的。具体如下图:
https://i-blog.csdnimg.cn/direct/1ce1bd4a6f2f4e668c8e4925afa4830a.png
需要留意的是,虽然bit类型可以用于存储恣意大小的二进制数,但是在现实应用中,bit通常只是用于存储较小的数值。这是因为bit类型的空间效率相对较低,对于较大的数值,使用其他数据类型大概会更加符合。
2.2 浮点型
2.2.1 float
float用于存储近似值的浮点数,它表现单精度浮点数。由于浮点数是以二进制形式表现的,大概存在精度丢失的情况。下面我们通过具体实例来明白用法。
https://i-blog.csdnimg.cn/direct/abc1886615da41c4b58a8ede975e3a5f.png
上图中我们创建了一个名字为t3的表。其中包罗了一个字段a,其类型为float(4,2)。**float的语法格式为float(M,D),其中M表现总位数,D表现小数点后的位数。比方,float(4,2)表现统共4位,其中2位为小数位。**下面我们插入一些数据来看一下,如下图:
https://i-blog.csdnimg.cn/direct/b27239c345274be99d8bce64e421bcfa.png
那如果是插入长度大于4的数据呢?我们再来看下图:
https://i-blog.csdnimg.cn/direct/428d8e53937d41fc9b03bc458e66427f.png
正如上图所示,当小数位数大于两位时,会举行四舍五入。四舍五入就会产生进位,但必须保证进位后的小数也可以或许满足两位,也就是整数部分不得凌驾两位。这里可以看到float(4,2)的取值范围是-99.994 ~ 99.994。
下面再来看一下无符号的float,如下图:
https://i-blog.csdnimg.cn/direct/1cbdf1c2a3544d13b4868d1d23987c61.png
插入数据:
https://i-blog.csdnimg.cn/direct/328ef5d9f12a4d179f8f8ffb7892cafe.png
但是负数就不能再举行插入了,如下图:
https://i-blog.csdnimg.cn/direct/328b49005bc34a7aba99b551ff10c253.png
其实在这里就可以发现,float(M,D)中的M和D限制了我们的数据范围,其次就是有符号和无符号的区别。float可以表现最大值为3.402823e+38的正或负实数,所占用的字节为4字节。
在MySQL中,如果不指定float类型的总位数和小数点后的位数,默认情况下float类型的总位数是其最大取值范围。
https://i-blog.csdnimg.cn/direct/bce997eee37344008536d050819be2a0.png
这里可以看到,float一旦数据较大,就会有精度损失。一样平常情况下提供6位精度。
这意味着float类型可以存储大约6位有效数字的数据,但现实精度大概受到存储数据时的舍入毛病的影响。
2.2.2 decimal
decimal用于精确存储数字,它表现定点数,可以或许保证精度不会丢失。
decimal的语法格式为DECIMAL(M,D),其中M表现总位数,D表现小数点后的位数,比方,DECIMAL(10,2)表现统共10位,其中2位为小数位。
https://i-blog.csdnimg.cn/direct/25b46972153d4b11b5fa2a308cceed1d.png
这里可以看到,decimal类型精度并没有丢失。decimal与float都是用来存储浮点数的,用法也是相同的,差异的是,decimal类型存储的数字是精确的,不会丢失精度。decimal占用的空间为8字节。
三、字符串类型
3.1 char
char类型在mysql中是一个经常使用的类型。
https://i-blog.csdnimg.cn/direct/8763210d68b2493fa0d7f3dc459f5695.png
这里界说了一个名字为str的字段,其属性为char(5),也就是最多可存储5个字符。插入数据来看一下:
https://i-blog.csdnimg.cn/direct/28d1c1fe00ff4a28906f4025e0c07fd4.png
这里可以看到,一旦插入的字符长度凌驾5,就不会让你插入了。**【留意】在mysql中,char(5)中的5指的是5个字符,并不是5个字节。**以是在这里最多也可以插入5个汉字。
https://i-blog.csdnimg.cn/direct/708c010ba494431aa846db31f6297cbb.png
在差异编码中,一个字符所占的字节个数是差异的。比如utf8中一个字符占3个字节,而gbk中一个字符占2个字节。char(5)就是指可以或许最多插入5个字符。如许用户在使用时就不用关心字节数的问题了。
char也是有字符长度上限的,char的字符长度上限是255。
https://i-blog.csdnimg.cn/direct/7ff24830e7d4443ab3fecadeae9a71d6.png
3.2 varchar
varchar也是用来存储字符的数据类型。使用方法和char相同。
https://i-blog.csdnimg.cn/direct/92683db3f658433989ea594fe1d15970.png
那么 varchar 和 char 有什么区别呢?就char(10) 和 varchar(10) 来阐明,无论char中现实存储的字符串长度是多少,char始终占用10个字符长度的存储空间。但是varchar是一种可变长度的字符类型,意味着它只占用现实存储数据所需的存储空间。我们在varchar中只存储5个字符的话,那么varchar只占用5个字符长度的空间。
关于varchar(len),len到底是多大,这个len值,和表的编码密切相干:
[*]varchar长度可以指定为0~65535之间的值,但是有1-3个字节用于记载数据大小(varchar是变长的),以是说有效字节数是65532。
[*]当我们的表的编码是utf8时,varchar(n)的参数n最大值是65532/3=21844(因为utf中,一个字符占用3个字节);如果编码是gbk,varchar(n)的参数n最大值是65532/2=32766(因为gbk中,一个字符占用2个字节)。
3.3 char和varchar的比较
[*]CHAR数据类型:
[*]CHAR是一种固定长度的字符类型,意味着它始终占用固定命量的存储空间。
[*]当界说一个CHAR列时,您需要指定该列的固定长度。比方,CHAR(10)表现该列将始终存储10个字符。
[*]无论现实存储的字符串长度是多少,CHAR始终占用指定长度的存储空间。
[*]CHAR适合存储长度固定的字符串,比方邮政编码或固定长度的标识符。
[*]VARCHAR数据类型:
[*]VARCHAR是一种可变长度的字符类型,意味着它只占用现实存储数据所需的存储空间。
[*]当界说一个VARCHAR列时,您需要指定该列可存储的最大长度。比方,VARCHAR(100)表现该列可以存储最多100个字符,但现实存储的字符串长度可以少于100个字符。
[*]VARCHAR适合存储长度可变的字符串,比方用户输入的文本或变长的形貌信息。
【主要区别】
[*]存储方式:CHAR是固定长度的,而VARCHAR是可变长度的。这意味着在使用CHAR时,数据将按固定长度存储;而使用VARCHAR时,额外的空间将被用来存储数据长度信息。
[*]性能:CHAR由于固定长度和提前分配的空间,其性能通常比VARCHAR要快。特别是当已知要存储的字符串长度时。而VARCHAR因为其灵活性(读取时需要先读取存储字符串的长度,再访问指定长度的空间),大概稍慢一些。
[*]空间使用:CHAR使用固定的空间来存储数据,因此大概会因为并没有使用全部空间而造成空间的浪费。但VARCHAR使用额外空间来存储数据长度信息,相对来说空间利用率较高。
[*]可变字段:如果一个字段的数据长度大概会有所差异,使用VARCHAR大概会更好,因为它答应更大的数据长度。
选择使用哪种类型取决于具体需求。如果知道要存储的字符串的长度,并且长度是固定的,CHAR大概是一个好选择。然而,如果不确定字符串的长度,大概需要更大的灵活性,使用VARCHAR大概更符合。
四、日期与时间类型
在前面的文章使用过到data类型。该类型就是属于日期类型的。常见的日期类型有:
[*]date:日期格式为 ‘YYYY-MM-DD’,占用三字节。
[*]datetime:时间日期格式为 ‘YYYY-MM-DD HH:MM:SS’,占用八字节。
[*]timestamp:时间戳,从1970年开始的。格式为 ‘YYYY-MM-DD HH:MM:SS’,占用四字节。
https://i-blog.csdnimg.cn/direct/051e492be044472b99071beaf23f69e6.png
通过上图可以看出,timestamp时间戳是不答应为空的,并且他是有默认值的。默认值就是当前的时间戳。插入数据看一下:
https://i-blog.csdnimg.cn/direct/5e3f90a160914e70b89bfb51d969697f.png
看到并没有插入时间戳时会自动插入和更新的。这里的更新是指的每当对表举行修改操作时,时间戳就会更新。
在使用这些数据类型时,需要根据现实需求选择符合的类型。如果只需要存储日期,选择DATE类型;如果需要存储日期和时间,选择DATETIME或TIMESTAMP类型,根据需要考虑是否需要自动更新功能。TIMESTAMP常用于的就是评论时记载时间大概发表内容时的时间。
五、枚举与聚集类型
5.1 enum
enum类型是一种字符串对象的类型,用于界说一个列可以包罗的大概值的有限列表。语法:enum(‘value1’, ‘value2’, …)。其中,‘value1’, 'value2’等是列答应的枚举值。我们直接看一个现实的例子。如下图:
https://i-blog.csdnimg.cn/direct/da45ba13879b4ba7b912a2a0071c95db.png
当我们再插入数据时,插入hobby属性时,就可以从我们的枚举列表中举行选择其中一个举行插入。如下图:
https://i-blog.csdnimg.cn/direct/8c73a17492a34cb795ca1d85c41d3a9e.png
如上图所示,插入的数据并不是枚举中的属性值,就会报错。出于效率考虑,这些值现实存储的是“数字”,因此这些选项的每个选项值依次对应如下数字:1,2,3,…最多65535个;当我们添加枚举值时,也可以添加对应的数字编号(枚举中仍旧何以使用下标举行选择所要插入的数据)。如下图:
https://i-blog.csdnimg.cn/direct/56da0d9a3dd04d0595846a06c6aecc56.png
但是需要留意的一点是:枚举中的第一个元素下标是从1开始的,并不是从0开始的。
5.2 set
通过对上述的枚举的明白后,我们发现在很多情况下一个人的爱好会有很多,并不是只有一个。但是枚举类型只能一次选一个。这时间我们就可以使用set类型。
SET是一种字符串对象,用于界说一个列可以包罗的大概值的多选列表。语法:SET(‘value1’, ‘value2’, …)。其中,‘value1’, 'value2’等是列答应的多选值。我们可以直接通过之前学的对表举行修改,把hobby的类型改成set。具体如下图
https://i-blog.csdnimg.cn/direct/24ad5df30a364629be50538e25fe3f3d.png
插入一些数据,具体如下图:
https://i-blog.csdnimg.cn/direct/a824c99ec9384813a6ca164d3aeeaf3c.png
通过上图可以看到,再插入数据时我们可以从set聚集中一次选多个数据举行插入,也可一次只选一个数据。set聚集设定只是提供了多少个选项的值,终极一个单位格中,计划可存储了其中恣意多个值;**而且出于效率考虑,这些值现实存储的也是“****数字”,因此这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,…最多64个。我们再来通过数字举行插入,**具体如下图:
https://i-blog.csdnimg.cn/direct/0ce4054121f448bf8c6bcab4405a046d.png
【留意】3是1和2相加的结果,7是1和2和4相加的结果。我们可对应set聚集举行检察。
虽然可以用数字添加枚举,但是不建议在添加枚举值,聚集值的时间采用数字的方式,因为不利于阅读,且后期维护成本较高。
5.3 查找
find_in_set()是 MySQL 中的一个函数,用于在逗号分隔的字符串列表中查找指定的字符串。它的作用是在一个逗号分隔的字符串列表中查找指定的值,并返回该值在列表中的位置。使用方法:
FIND_IN_SET(search_string, string_list)
其中:
[*]search_string是要查找的字符串。
[*]string_list是逗号分隔的字符串列表,它包罗要搜索的多个字符串。
返回值:
[*]如果search_string在string_list中找到,则返回它在列表中的位置(从 1 开始)。
[*]如果未找到,则返回 0。
https://i-blog.csdnimg.cn/direct/a16dc1f81de1431dabb335a4b10cf013.png
我们就使用find_in_set()举行查找喜欢篮球的,结果如下图:
https://i-blog.csdnimg.cn/direct/1b80e23523e248848d7fd3030e8d215f.png
固然,也可以在后面跟任何你想筛选的条件。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]