mysql创建字段非空NOT NULL的好处
2016-11-22 11:21
253 查看
详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt338
很多表都包含可为 NULL (空值) 的列,即使应用程序井不需要保存 NULL 也是如此 ,这是因为可为 NULL 是列的默认属性。通常情况下最好指定列为 NOT NULL,除非真 的需要存储 NULL 值。
如果查询中包含可为 NULL 的列,对 MySQL 来说更难优化 ,因为可为 NULL 的列使 得索引、索引统计和值比较都更复杂 。可为NULL 的列会使用更多的存储空间 ,在 MySQL 里也需要特殊处理 。当可为NULL 的列被索引肘,每个索引记录需要一个额 外的字节,在 MyISAM 里甚至还可能导致固定大小 的索引 (例如只有一个整数列的 索引) 变成可变大小的索引。
通常把可为 NULL 的列改为 NOT NULL 带来的性能提升比较小 ,所以 (调优时) 没有 必要首先在现有schema中查找井修改掉这种情况 ,除非确定这会导致问题。但是, 如果计划在列上建索引 ,就应该尽量避免设计成可为 NULL 的列。当然也有例外 ,例如值得一提的是,InnoDB 使用单独的位 (bit ) 存储 NULL 值 ,所 以对于稀疏数据由有很好的空间效率 。但这一点不适用于MyISAM 。
很多表都包含可为 NULL (空值) 的列,即使应用程序井不需要保存 NULL 也是如此 ,这是因为可为 NULL 是列的默认属性。通常情况下最好指定列为 NOT NULL,除非真 的需要存储 NULL 值。
如果查询中包含可为 NULL 的列,对 MySQL 来说更难优化 ,因为可为 NULL 的列使 得索引、索引统计和值比较都更复杂 。可为NULL 的列会使用更多的存储空间 ,在 MySQL 里也需要特殊处理 。当可为NULL 的列被索引肘,每个索引记录需要一个额 外的字节,在 MyISAM 里甚至还可能导致固定大小 的索引 (例如只有一个整数列的 索引) 变成可变大小的索引。
通常把可为 NULL 的列改为 NOT NULL 带来的性能提升比较小 ,所以 (调优时) 没有 必要首先在现有schema中查找井修改掉这种情况 ,除非确定这会导致问题。但是, 如果计划在列上建索引 ,就应该尽量避免设计成可为 NULL 的列。当然也有例外 ,例如值得一提的是,InnoDB 使用单独的位 (bit ) 存储 NULL 值 ,所 以对于稀疏数据由有很好的空间效率 。但这一点不适用于MyISAM 。
相关文章推荐
- 如何在MySQL&Oracle下创建自动递增字段
- mysql下创建字段并设置主键的php代码
- MySQL创建计算字段——MySQL系列(五)
- MySQL导出多个表数据且insert语句带上字段,不要创建表结构语句
- MySql创建索引、删除索引、新增字段、删除字段、修改字段语句
- PB里创建的字段,默认是not null
- MySql使用Index关键字为字段时创建表不成功
- mysql 添加字段 修改字段为not null
- MySQL学习足迹记录08--创建计算字段--Concat(),AS
- MySQL中不能创建自增字段的解决方法
- 用sql命令修改数据表中的一个字段为非空(not null)的语句
- 在Oracle、MySQL、MS SQL Server中创建自动增长字段
- [轉]mysql 自动增长字段创建
- MySQL 字段约束 null, not null, default, auto_increment
- mssql 和 mysql的区别,让自动增长列自动递增就必须指定其他列名,mysql创建事务,如果插入的字符多余字段的值,会报错?截取插入?带输出参数的存储过程,带If else判断
- mysql 创建表时 日期字段默认值为当前时间
- 常用数据库的自增字段创建方法汇总_DB2_Oracle_MySQL_PostgreSQL_SQL Server_Sybase
- MYsql 创建计算字段 CONCAT
- 为什么mysql字段要设置为not null?
- mysql 查询表中字段的信息,及修改字段not null