为什么字段尽可能用NOT NULL,而不是NULL
2015-09-07 14:26
176 查看
NULL为什么多人用?
1、NULL是创建数据表时默认的,初级或不知情的或怕麻烦的程序员不会注意这点。
2、很多人员都以为not null 需要更多空间,其实这不是重点。
3、重点是很多程序员觉得NULL在开发不用去判断插入数据,写sql语句的时候更方便快捷。
网上很多资料都有写:
Mysql官网文档:
“NULL columns require additional space in the rowto record whether their values are NULL. For MyISAM tables, each NULL columntakes one bit extra, rounded up to the nearest byte.”
-----------------------------------------------
Mysql难以优化引用可空列查询,它会使索引、索引统计和值更加复杂。可空列需要更多的存储空间,还需要mysql内部进行特殊处理。可空列被索引后,每条记录都需要一个额外的字节,还能导致MYisam 中固定大小的索引变成可变大小的索引
--------这也是《高性能mysql第二版》介绍的
解读:
“可空列需要更多的存储空间”:需要一个额外字节作为判断是否为NULL的标志位
“需要mysql内部进行特殊处理”:http://www.phpben.com/?post=69 这是mysql索引统计,里面有介绍mysql怎么处理NULL。
注意:但把NULL列改为NOT NULL带来的性能提示很小,除非确定它带来了问题,否则不要把它当成优先的优化措施,最重要的是使用的列的类型的适当性.
来自:http://blogread.cn/it/article/5967?f=hot3
1、NULL是创建数据表时默认的,初级或不知情的或怕麻烦的程序员不会注意这点。
2、很多人员都以为not null 需要更多空间,其实这不是重点。
3、重点是很多程序员觉得NULL在开发不用去判断插入数据,写sql语句的时候更方便快捷。
网上很多资料都有写:
Mysql官网文档:
“NULL columns require additional space in the rowto record whether their values are NULL. For MyISAM tables, each NULL columntakes one bit extra, rounded up to the nearest byte.”
-----------------------------------------------
Mysql难以优化引用可空列查询,它会使索引、索引统计和值更加复杂。可空列需要更多的存储空间,还需要mysql内部进行特殊处理。可空列被索引后,每条记录都需要一个额外的字节,还能导致MYisam 中固定大小的索引变成可变大小的索引
--------这也是《高性能mysql第二版》介绍的
解读:
“可空列需要更多的存储空间”:需要一个额外字节作为判断是否为NULL的标志位
“需要mysql内部进行特殊处理”:http://www.phpben.com/?post=69 这是mysql索引统计,里面有介绍mysql怎么处理NULL。
注意:但把NULL列改为NOT NULL带来的性能提示很小,除非确定它带来了问题,否则不要把它当成优先的优化措施,最重要的是使用的列的类型的适当性.
来自:http://blogread.cn/it/article/5967?f=hot3
相关文章推荐
- JS 之继承
- Home键和back键下 Activity的生命周期变化
- iOS 百度地图坐标标注
- DATAGUARD中手工处理日志v$archive_GAP的方法
- java基础—1.java概述及编程知识
- 压缩与解压iOS
- android fragment
- http://www.cocoachina.com/ios/20150907/13336.html
- 野生程序员的故事
- 通过 回调让Activity和Fragment及时交互
- win7 64位 下,进程可申请的堆空间
- Java 之 调用.Net的 WebService 整理
- Android Fragment 真正的完全解析(上) add remove replace detach attach hide show
- 设置textView的行间距
- getResourceAsStream的用法
- Android Studio优化配置
- 「改进的快速排序」时间复杂度接近O(n)
- 绕过XSS过滤规则 : Web渗透测试高级XSS教程
- 码农们可以优越,并且应该优越
- 揭开HTTP网络协议神秘面纱系列(一)