notnull

时间:2024-12-12 20:51:42编辑:笔记君

SQL的主键,约束 有什么用

主键就是每个表唯一的一个标识符

类似于学号

好比一个表

学号 姓名 性别
1201 李三 男
1202 李四 女
1203 李三 女
1204 王二 男

这个表里面学号就是主键
只要查找1201 就能找到叫李三的男生
姓名和性别不能作为主键因为会有重复
查找李三会出来两个
查找男也会出来两个
不是唯一值 所以不可以作为主键

不知道你看懂了么...


为什么字段尽可能用NOT NULL,而不是NULL

字段尽可能用NOT NULL,除非特殊情况。这句话在mysql优化的文章被大量的引用,但却不说明原因,下面就讲述一下相关内容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内部进行特殊处理”:注意:但把NULL列改为NOT NULL带来的性能提示很小,除非确定它带来了问题,否则不要把它当成优先的优化措施,最重要的是使用的列的类型的适当性.


上一篇:鲸鲨馆

下一篇:没有了