背景:时下都流行enum类型的使用tinyint,那enum就真没有用的价值了么?
PHP低级编程的兄弟是这样来看这个问题的,我作下笔录如下,期望能客观的理解这个enum字段的优点及缺点:
膘哥观点:
    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。

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

简单观点:
   少用,一般都是用tinyint替代。

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

中庸观点:
   a=1是插入enum的第一个值,尤其php弱类型的,如果int的,很少有人在sql里加双引号,基本上是不加引号的。

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

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

view plain print ?
  1. 表结构如下:
  2. CREATE TABLE `enum2tinyint` (
  3. `switchs` enum('none','success','fail','delete','skip','1') DEFAULT NULL,
  4. `switch` tinyint(1) NOT NULL,
  5. KEY `switchs` (`switchs`)
  6. ) ENGINE=InnoDB DEFAULT CHARSET=utf8
  7. 正常带引号插入enum:
  8. INSERT INTO `test`.`enum2tinyint` (`switchs`, `switch`) VALUES ('1', '1');
  9. 1 1
  10. PHP的弱类型问题,特别是对int类型的情况,实践如下:
  11. 如果没有带引号插入enum字段后如下(是第一个值none):
  12. INSERT INTO `test`.`enum2tinyint` (`switchs`, `switch`) VALUES (1, '1');
  13. none 1
  14. 如果没有带引号插入enum字段后如下(是第2个值success):
  15. INSERT INTO `test`.`enum2tinyint` (`switchs`, `switch`) VALUES (2, '1');
  16. success 1

结论:要插入enum的值,字段必须加引号,不加引号当然是数字,数字就是key,不是value。
规劝:
1)enum是整型这样的错误很容易发生,尤其是php弱类型的,一般新来一个人,没注意enum类型,就会犯错。
2)数据库说明清楚的话,或者可选择的全是字符串的话,还没什么,但是里面有数字,难免有新手犯错,养成加引号的习惯很重要。
最终结论:
历史原因,要把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

为何表示的最大正数比最小负数的绝对值少1呢?
第一位是符号位,1表示负数
所以负数可以到128,正数只能到127
-128正127
如:0111 1111  正数  ,负数 1111 1111
提问:
Mysql里int(1)和int(11)差别很大的,mysql的int,有个属性 ,UNSIGNED ZEROFILL  后面的ZEROFILL,就是有定义的位数不够则用零补齐对齐一下(这儿可能涉及到索引的性能罢):int,  长度(M)=5, 属性=UNSIGNED ZEROFILL(无符号,用0来填充位数),00001,00002。
但这个tinyint呢,tinyint(1)和tinyint(4)一样的?
看这文章后:http://blog.csdn.net/lysygyy/article/details/5983433
我估计:mysql这块对一个字节不像int这种四个字节要进行对其前部分进行部分字节索引,如果说tinyint(1)和tinyint(4)是一样的表示范围情况下,但mysql对tinyint数字长度位数作了可设置的限定,从理论上说其存在硬盘里的字节是不一样才是合乎逻辑的,这块估计还是为了对字节进行对齐方便索引等,以提升效率为主罢,l如:ike keyword%    索引有效,如果统一对齐,索引效果会不会更好呢?我也只是猜测。
————————————————————————————————————————————————————————————————————
在网上找了下这个enum的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字节。

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

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

mysql中关于bit,enum,tinyint三种数据类型的差别 :
http://blog.csdn.net/shadowsniper/article/details/7071004

慎用mysql的enum字段:
http://www.neatstudio.com/show-1498-1.shtml

为嘛子要慎用mysql的enum字段?(来自向东的原创博客)相关推荐

  1. mysql数据库enum部分乱码_要慎用mysql的enum字段的原因

    PHP低级编程的兄弟是这样来看这个问题的,我作下笔录如下,期望能客观的理解这个enum字段的优点及缺点: 膘哥观点: enum有优点.但个人觉得...缺点更多,客观的讲:优点主要是在建数据 库的时候就 ...

  2. mysql 禁止使用enum_要慎用mysql的enum字段的原因

    PHP低级编程的兄弟是这样来看这个问题的,我作下笔录如下,期望能客观的理解这个enum字段的优点及缺点: 膘哥观点: enum有优点.但个人觉得...缺点更多,客观的讲:优点主要是在建数据 库的时候就 ...

  3. enum 中文 mysql_要慎用mysql的enum字段的原因_MySQL

    PHP低级编程的兄弟是这样来看这个问题的,我作下笔录如下,期望能客观的理解这个enum字段的优点及缺点: 膘哥观点: enum有优点.但个人觉得...缺点更多,客观的讲:优点主要是在建数据 库的时候就 ...

  4. mysql乐观锁总结和实践 - 青葱岁月 - ITeye博客

    mysql乐观锁总结和实践 - 青葱岁月 - ITeye博客

  5. 分享Node.js + Koa2 + MySQL + Vue.js 实战开发一套完整个人博客项目网站

    这是个什么的项目? 使用 Node.js + Koa2 + MySQL + Vue.js 实战开发一套完整个人博客项目网站. 博客线上地址:www.boblog.com Github地址:https: ...

  6. MySQL的优化 - 邱乘屹的个人技术博客

    MySQL的优化 MySQL的优化 为什么要MySQL优化? MySQL的优化 字段设计优化 适应遵循数据库三范式 引擎的选择 适应选择MyIsam & InnoDB 索引 索引也会消耗内存空 ...

  7. windows mysql 自动备份_windows mysql 自动备份的几种方法总结--岁月博客提供

    因为管理几台windows网站服务器,需要定时对mysql进行备份,每次都是手动,也经常忘记,所以就尝试了各种自动备份方法,网上也有安装mysql自动备份软件,尝试过不太好用.这里总结下通过bat+定 ...

  8. mysql左链表右链表区别_MySql链表语句--博客园老牛大讲堂

    为什么链表?--博客园老牛大讲堂 因为表与表之间有关系,而且查询时需要两张表的某些数据. 链表的前提是:表与表之间必须设置主外键吗? 不是的,其实表与表之间不需要设置主外键关系,用数据库语句就可以实现 ...

  9. llmp重启mysql_LNMP使用中mysql宕机挂掉后自动重启脚本 - 老牛博客

    昨晚某个重要网站的mysql挂掉了,今早睡了个懒觉,发现出问题时已经整整过去7个小时,美刀打水漂了 以前就一直要弄个脚本来自动重启,但是一直没出过问题,人就变懒了 不行,这次还是弄个无人值守的脚本帮我 ...

最新文章

  1. 开发者数量2025年预计破亿,GitHub最新年度报告来啦!
  2. 博客作业05--查找
  3. Matlab画图时的线型、标记以及颜色简记
  4. Excel文件读写操作(一)
  5. Java 应用中的日志
  6. 使用wrk进行性能测试
  7. 关于eclipse里启动Tomcat访问不到8080页面的问题
  8. STM32F7xx —— QSPI
  9. 展示一个基本的正则用例
  10. (48)System Verilog 类中变量随机激励数组数据
  11. java addbatch_使用addBatch java时丢失数据
  12. 关于Hbase的cache配置
  13. linux怎么备份文件夹命令,linux环境文件备份命令
  14. 微信公众号运营技巧总结
  15. 修电脑入门名词及等级划分
  16. springboot+redis实现文章浏览量记录
  17. 虚拟机上WindowsXP系统下载QQ和打开https网站证书问题打不开解决
  18. 三次方程求根公式例子二
  19. 20220408-CH9121串口转以太网模块学习
  20. 第91届奥斯卡奖公布提名名单《罗马》《宠儿》10项提名领跑

热门文章

  1. [置顶] iphone 软解那点事 (二)
  2. “内存或磁盘空间不足 Microsoft Excel无法再次打开...”的解决方法
  3. sizebox模型下载_box-sizing解决盒模型和form元素统一风格的问题
  4. 0ctf freenote
  5. 2014 HITCON——stkof
  6. wps python 自动化_Python实现合同文档自动化生成
  7. 展锐推出线上平台坦克邦打造新生态
  8. 王者荣耀无限火力服务器,王者荣耀无限火力4.0
  9. Flash AIR文件操作:使用文件对象操作文件和目录
  10. 高并发下的订单与库存的处理