首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

要慎用mysqlenum字段的原因

PHP低级编程的兄弟是这样来看这个问题的,我作下笔录如下,期望能客观的理解这个enum字段的优点及缺点: 膘哥观点:     enum有优点。但个人觉得。。。...,这是PHP和 mysql 在使用enum 最大的问题。所以。。安心点啦。干脆点直接tinyint。...类型的情况,实践如下:  如果没有带引号插入enum字段后如下(是第一个值none):  1 2 INSERT INTO `test`....`enum2tinyint` (`switchs`, `switch`) VALUES (1, '1'); none 1 如果没有带引号插入enum字段后如下...这种字段的重复内容过多的,索引建不建,关系不大,这种在mysql叫索引的势太低,其查询效果不太好 https://www.cnblogs.com/-mrl/p/5096447.html 发布者:全栈程序员栈长

63620
您找到你想要的搜索结果了吗?
是的
没有找到

MySQLENUM类型学习--MySql语法

这说明你可以使用下面的SELECT语句来找出分配了非法ENUM值的行: · mysql> SELECT * FROM tbl_name WHERE enum_col=0;...当创建表时,ENUM成员值的尾部空格将自动被删除。 当检索时,保存在ENUM列的值使用列定义中所使用的大小写来显示。请注意可以为ENUM列分配字符集和 校对规则。...例如,你可以这样从ENUM列搜索数值值: mysql> SELECT enum_col+0 FROM tbl_name; 如果将一个数字保存到ENUM列,数字被视为索引,并且保存的值是该索引对应的枚举成员...(换句话说,ENUM值根据索引编号进行排序)。例如,对于ENUM('a','b'),'a'排在'b'前面,但对于ENUM('b','a'),'b'排在'a'前面。...如果你想要确定一个ENUM列的所有可能的值,使用SHOW COLUMNS FROM tbl_name LIKE enum_col,并解析输出中第2列的ENUM定义。

1.3K20

mysql密码字段类型_MySQL 字段类型

许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分(UNSIGNED)或者用零填补(ZEROFILL)。...unsigned 和 zerofill UNSIGNED 修饰符规定字段只保存正值,即无符号,而mysql字段默认是有符号的。...ENUM 类型字段可以从集合中取得一个值或使用 null 值,除此之外的输入将会使 MySQL 在这个字段中插入一个空字符串。...一个 ENUM 类型最多可以包含 65536 个元素,其中一个元素被 MySQL 保留,用来存储错误信息,这个错误值用索引 0 或者一个空字符串表示。...并且与 ENUM 类型相同的是任何试图在 SET 类型字段中插入非预定义的值都会使 MySQL 插入一个空字符串。

14.4K20

MySQL枚举类型enum字段在插入不在指定范围的值时, 是否是”插入了enum的第一个值”?…「建议收藏」

刚刚在看>一书的”ENUM类型”一节, 以下面的代码举例, 得出结论: “还可以看出对于不在ENUM指定范围内的值时, 并没有返回警告, 而是插入了enum(‘M’, ‘F’)的第一个值...还是因为MySQL的版本问题呢 mysql> create table test(gender enum('M', 'F')); Query OK, 0 rows affected (0.12 sec)...Null | Key | Default | Extra | +--------+---------------+------+-----+---------+-------+ | gender | enum...> 不同 MySQL 版本处理方式不一样,像 5.5 这些默认不严格的会自动处理,5.7 及以上的默认是严格处理,所以会出错。...在 MySQL 枚举类型的“八宗罪” 这篇文章的第七条,文中提到了,如果不合法会被处理成空字符串,在后一段中又提到了因为类型的缘故,会根据枚举索引去取值。

1.7K20

Mysql5.7版本中数据表字段可用的类型

,然后我就开始了对这几种类型字符串的测试,接着就悲剧了,测试多次之后发现创建为nvarchar类型的字段居然是varchar类型的,再查询官方文档后发现,当前版本(5.7.21)的Mysql根本就没有nvarchar...类型的字段,白白浪费了时间,所以要把Mysql支持的字段列举在这里,方便后面查找使用。...从13年开始工作到现在,数据库主要使用Mysql,关于常使用的字段类型无非 int、char、varchar、blob、datetime 这几种,工作之前用的最多的是SqlServer,其次就是Oracle...和db2了,当时数据库的规模也不大,也没有注意到字段都有哪些类型,基本也是使用上述几种,因为今天在Mysql中的数据类型这栽了跟头,所以查了下官方文档,看看到底都有哪些类型。...,binary,bit,blob,char,date,datetime,decimal,double,enum,float,geometry,geometrycollection,int,integer

94330

MySQL字段类型_mysql数据库字段类型

MySQL 支持大量的字段类型,其中常用的也有很多。...定点型字段类型有 DECIMAL 一个,主要用于存储有精度要求的小数。 DECIMAL 从 MySQL 5.1 引入,列的声明语法是 DECIMAL(M,D) 。...char 类型是定长的,MySQL 总是根据定义的字符串长度分配足够的空间。当保存 char 值时,在它们的右边填充空格以达到指定的长度,当检索到 char 值时,尾部的空格被删除掉。...3.日期时间类型 MySQL支持的日期和时间类型有 YEAR 、TIME 、DATE 、DATETIME 、TIMESTAMP,几种类型比较如下: 涉及到日期和时间字段类型选择时,根据存储需求选择合适的类型即可...总结: 本篇文章主要介绍了 MySQL 中常用的字段类型,平时用到的字段类型基本都在这里了,以一张思维导图总结如下: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

19.3K10

mysql alter 修改字段类型_Mysql必读mysql 增加修改字段类型及删除字段类型「建议收藏」

MysqL必读MysqL 增加修改字段类型及删除字段类型》要点: 本文介绍了MysqL必读MysqL 增加修改字段类型及删除字段类型,希望对您有用。如果有疑问,可以联系我们。...(字段名1[,字段名2 …]); MysqL> alter table tablename add index emp_name (name);加主关键字的索引 MysqL> alter table...);删除某个索引 MysqL>alter table tablename drop index emp_name;修改表: MysqL> ALTER TABLE table_name ADD field_name...field_type;修改原字段名称及类型: MysqL> ALTER TABLE table_name CHANGE old_field_name new_field_name field_type...;删除字段MysqL> ALTER TABLE table_name DROP field_name; 总结 如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

10.1K10

MySQL修改字段名、修改字段类型

修改字段 类型、名、注释、类型长度、默认值 ALTER TABLE 表名 MODIFY [COLUMN] 字段名 新类型 新类型长度 新默认值 新注释; -- COLUMN关键字可以省略不写...'注释'; 修改字段名 -- 字段名称未改变,修改字段类型、类型长度、默认值、注释 ALTER TABLE 表名 CHANGE [column] 旧字段名 新字段名 新数据类型; alter...column1 decimal(10,1) DEFAULT NULL COMMENT '注释' alter table table1 change column1 column2; -- 报错 mysql...Duplicates: 0 Warnings: 0 更改表名 Table 从 db_a 要搬到 db_b RENAME TABLE db_a.old_table TO db_b.new_table; MySQL...Table 改名字(重命名) RENAME TABLE old_table TO new_table; MySQL 两个 Table 互换名 RENAME TABLE old_table TO tmp_table

24.3K31
领券