mysql创建字段非空NOT NULL的好处

Posted grefr

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql创建字段非空NOT NULL的好处相关的知识,希望对你有一定的参考价值。

详见: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 。

以上是关于mysql创建字段非空NOT NULL的好处的主要内容,如果未能解决你的问题,请参考以下文章

mysql中中文乱码问题

Spring Mongo 仅通过新 POJO 的非空字段进行更新

PG11新特性解读:新增非空默认值字段不需要重写表-原理

mysql workbench中PK,NN,UQ,BIN,UN,ZF,AI字段类型标识说明

mysql 笔记3

oracle中clob字段怎么查询非空列_20180517