Mysql学习要慎用mysql的enum字段的原因

Mysql学习要慎用mysql的enum字段的原因,第1张

概述介绍《Mysql学习要慎用mysql的enum字段原因》开发教程,希望对您有用。

《MysqL学习要慎用MysqL的enum字段的原因》要点:
本文介绍了MysqL学习要慎用MysqL的enum字段的原因,希望对您有用。如果有疑问,可以联系我们。

MysqL应用PHP低级编程的兄弟是这样来看这个问题的,我作下笔录如下,期望能客观的理解这个enum字段的优点及缺点:

MysqL应用膘哥观点:
    enum有优点.但个人觉得...缺点更多,客观的讲:优点主要是在建数据 库的时候就可以把一些值给规范好.缺点是..enum不适合PHP.主要是PHP是弱类型,如:你insert into ..... set a= 1,你没法知道你是想 a= '1' 还是 a= 1(a='1'是插入值1,a=1是插入enum的第一个值,尤其PHP弱类型的,如果int的,很少有人在sql里加双引号.),这是PHP和MysqL 在使用enum 最大的问题.所以..安心点啦.干脆点直接tinyint.

MysqL应用单曲观点:
    我觉得没什么优点,对数字型的enum,简直就是梦魇,boolean  tinyint(1) 0,1 status  tinyint(1)  1,2,3,4,5,6..tinyint欢淫你~~.如:audit_result enum(1,3),set audit_result = 1;...容易出现膘哥所说的混淆.

MysqL应用简单观点:
   少用,一般都是用tinyint替代.

MysqL应用天枫观点:
   我觉得除了状态直观  没什么优点,我一般直接int,tinyint([1or2or3]) 到底有啥区别?(后面会简单探讨下,这里面的1or2or3区别.)

MysqL应用中庸观点:
   a=1是插入enum的第一个值,很少有人在sql里加双引号,基本上是不加引号的.

MysqL应用竖琴螺观点:
   六种情况就:tinyint(1)  -1,-2,1,4

MysqL应用上面各种观点重点集中在PHP这种弱类型语言对引号不重视,程序员不写容易引起插入的语句不是自己想要的结果的问题,容易出现int时没有用引号导致插入了新值而不是定的那个值:

MysqL应用表结构如下: 

MysqL应用CREATE table `enum2tinyint` (  `switchs` enum('none','success','fail','delete','skip','1') DEFAulT NulL,`switch` tinyint(1) NOT NulL,KEY `switchs` (`switchs`) ) ENGINE=InnoDB DEFAulT CHARSET=utf8 

MysqL应用 
正常带引号插入enum: 

MysqL应用INSERT INTO `test`.`enum2tinyint` (`switchs`,`switch`) VALUES ('1','1'); 1 1 

MysqL应用PHP的弱类型问题,特别是对int类型的情况,实践如下: 
如果没有带引号插入enum字段后如下(是第一个值none): 

MysqL应用INSERT INTO `test`.`enum2tinyint` (`switchs`,`switch`) VALUES (1,'1'); none 1 

MysqL应用如果没有带引号插入enum字段后如下(是第2个值success): 

MysqL应用INSERT INTO `test`.`enum2tinyint` (`switchs`,`switch`) VALUES (2,'1'); success 1 

MysqL应用
结论:要插入enum的值,字段必须加引号,不加引号当然是数字,数字就是key,不是value.

MysqL应用规劝:
1)enum是整型这样的错误很容易发生,尤其是PHP弱类型的,一般新来一个人,没注意enum类型,就会犯错.
2)数据库说明清楚的话,或者可选择的全是字符串的话,还没什么,但是里面有数字,难免有新手犯错,养成加引号的习惯很重要.

MysqL应用最终结论:
历史原因,要把enum改成tinyint程序改动太大了,用了的没必要改・~,以后新建的时候,尽量使用tinyint就好.
这种字段的重复内容过多的,索引建不建,关系不大,这种在MysqL叫索引的势太低,其查询效果不太好:(英文是这么翻译的:https://justwinit.cn/post/1405/).
――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――
tinyint(1)和tinyint(4)一样的,都是-127到128或者0到256.unsigned属性全是正,和c语言unsigned int有点类似:
tinyint(1)   -128 ~ 127
tinyint(1) unsigned  0 ~ 255

MysqL应用为何表示的最大正数比最小负数的绝对值少1呢?
第一位是符号位,1表示负数
所以负数可以到128,正数只能到127
-128正127
如:0111 1111  正数 ,负数 1111 1111

MysqL应用提问:

MysqL应用MysqL里int(1)和int(11)差别很大的,MysqL的int,有个属性,UNSIGNED ZEROFILL  后面的ZEROFILL,就是有定义的位数不够则用零补齐对齐一下(这儿可能涉及到索引的性能罢):int,  长度(M)=5,属性=UNSIGNED ZEROFILL(无符号,用0来填充位数),00001,00002.

MysqL应用但这个tinyint呢,tinyint(1)和tinyint(4)一样的?

MysqL应用看这文章后:/article/53424.htm

MysqL应用我估计:MysqL这块对一个字节不像int这种四个字节要进行对其前部分进行部分字节索引,如果说tinyint(1)和tinyint(4)是一样的表示范围情况下,但MysqL对tinyint数字长度位数作了可设置的限定,从理论上说其存在硬盘里的字节是不一样才是合乎逻辑的,这块估计还是为了对字节进行对齐方便索引等,以提升效率为主罢,l如:ike keyword%    索引有效,如果统一对齐,索引效果会不会更好呢?我也只是猜测.
――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――

MysqL应用在网上找了下这个enum的MysqL的大体实现如下:

MysqL应用一)enum的存储原理我仔细查看了下手册.是这样的:
在建立这个字段时,我们会给他规定一个范围比如enum('a','b','c'),这时MysqL内部会建立一张hash结构的map表,类似:0000 -> a,0001 -> b,0002 -> c.
当我插入一条数据,此字段的值位a或b或c时,他存储在里面的不是这个字符,而是对应他的索引,也就是那个0000或0001或0002.
同样,enum在MysqL手册上的说明:
ENUM('value1','value2',...)
1或2个字节,取决于枚举值的个数(最多65,535个值)
除非enum的个数超过了一定数量,否则他所占的存储空间也总是1字节.

MysqL应用二)tinyint:
类型  字节  最小值  最大值
      (带符号的/无符号的)  (带符号的/无符号的)
tinyint  1  -128  127
他的最小存储所占空间也是1字节.

MysqL应用最后,Enum,既然要用它,就不必要使用什么0,2来代替实际的字符串了.甚至中文字符串.他并不会对数据库性能进行多余开销.因为对于它来说,你使用'0','1','2'和'张三','李四','王五'数据表所占的存储空间一样.但是考虑到我们实际应用时数据需要从db服务器回传到web app,所以在网络传输时,当然还是尽可能的传输小数据比较好.所以如果很在意这些,还是不用它好了.

总结

以上是内存溢出为你收集整理的Mysql学习要慎用mysql的enum字段的原因全部内容,希望文章能够帮你解决Mysql学习要慎用mysql的enum字段的原因所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1163148.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存