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时没有用引号导致插入了新值而不是定的那个值:

表结构如下:

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

正常带引号插入enum:

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

1 1

PHP的弱类型问题,特别是对int类型的情况,实践如下:

如果没有带引号插入enum字段后如下(是第一个值none):

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

none 1

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

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

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://www.bitsCN.com/article/53424.htm

我估计: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,所以在网络传输时,当然还是尽可能的传输小数据比较好。所以如果很在意这些,还是不用它好了。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

enum 中文 mysql_要慎用mysql的enum字段的原因_MySQL相关推荐

  1. 为嘛子要慎用mysql的enum字段?(来自向东的原创博客)

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

  2. mysql中数据库字段类型长度_Mysql数据库字段数据类型、长度详解

    一.数值类型 列类型 需要的存储量 TINYINT 1 字节 SMALLINT 2 个字节 MEDIUMINT 3 个字节 INT 4 个字节 INTEGER 4 个字节 BIGINT 8 个字节 F ...

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

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

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

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

  5. mysql两个字段相减_MySQL 中NULL和空值的区别?

    作为后台开发,在日常工作中如果要接触Mysql数据库,那么不可避免会遇到Mysql中的NULL和空值.那你知道它们有什么区别吗? 学不动了,也不想知道它们有什么区别.大兄弟,不行啊,要面试! 前些天我 ...

  6. mysql 查询 系统字段 自然日_Mysql查询用户留存/留存率问题用户n日(内)留存、某日新增用户n日(内)留存...

    Mysql查询用户留存/留存率语法 计算某日的客户在第n日再次出现的概率--用户n日留存率. 计算某日的客户在某个时间段内再次出现的概率--用户n日内留存率. 计算某日新增的用户在第n日再次出现的概率 ...

  7. mysql数据库时间字段看不懂_mysql数据库时间字段看不懂

    {"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],&q ...

  8. mysql 把一个字段的值_mysql把一个表某个字段的内容复制到另一张表的某个字段的SQL语句写法...

    需求:把一个表某个字段内容复制到另一张表的某个字段. 实现sql语句1: UPDATE file_manager_folder f1 LEFT OUTER JOIN file_manager_fold ...

  9. mysql 查询相同字段的数据_MySql 几种查询相同字段中相同数据,及删除相同字段的相同数据的方法...

    比如现在有一人员表  (表名:peosons) 若想将姓名.身份证号.住址这三个字段完全相同的记录查询出来 select   p1.*   from   persons   p1,persons   ...

最新文章

  1. putty和Xming server 结合完美在windows下显示linux GUI程序
  2. jsp页面发生异常跳转到友好页面
  3. 音视频(H264+G711)打包AVI文件
  4. 第十届蓝桥杯java B组—试题I 后缀表达式
  5. HDFS的exists函数解析
  6. 《C语言及程序设计》实践项目——三种循环语句
  7. Android之CheckBox进行代码设置setChecked(true)会触发setOnCheckedChangeListener事件
  8. 关于TCP/IP与数据传输
  9. npm 安装包报错 rollbackFailedOptional
  10. linux中nslookup命令功能,nslookup
  11. python做excel表格教程视频_基于Python实现excel表格读写
  12. 79-Spark Standalone架构设计要点分析
  13. apache支持.htaccess
  14. C++中static关键字用法详解
  15. 【老孙随笔】想学程序设计,先学人生设计!
  16. PHP - 日期和时间
  17. gaussian09使用教程linux,Gaussian 09 GaussView5.0使用教程.ppt
  18. 基于MyScript的C#版本手写板 准确的识别中文
  19. k2ttl救砖_无线路由救砖 ttl刷机教程
  20. win10玩武装突袭3一会就闪退的解决方法

热门文章

  1. 微信小程序----wx:key(Now you can provide attr wx:key for a wx:for to improve performance.)
  2. Speedoffice (Excel)中如何合并单元格
  3. 外汇交易都有哪些基本的交易策略
  4. 第九章 账务处理子系统设计
  5. Python解决ValueError: array must not contain infs or NaNs
  6. 基于java+swing的潜艇大战项目游戏(java+swing)
  7. 城市商业传说:打飞的吗?无人的那种
  8. Windows批处理 if判断详细介绍
  9. 「Rust笔记」Rust之自定义宏写法
  10. 网络攻防--网络防御技术