字段尽可能用NOT NULL,而不是NULL,除非特殊情况。可以负责任的告诉你这句话没有错,也不是以讹传讹,这句话首次出现在 MySQL 官网。
如果你读过《高性能 MySQL》这本书,在 4.1 节提到。把 NULL 改成 NOT NULL 对索引的性能并没有明显的提升。避免使用 NULL 的目的,是便于代码的可读性和可维护性。同时也便于避免下文即将出现的一些稀奇古怪的错误
时间格式
可以把时间的格式转换成百时间戳的格式保存,他们的区别:
datetime
1、允许为空值,可以自定义值,系统不会自动修改其值。
2、不可以设定默认值,所以在不允许为空值的情况下,必须手动指定datetime字段的度值才可以成功插入数据。
3、虽然不可以设定默认值,但是可以在指定datetime字段的值的时候使用now()变量来自动插入系统的当前时间。
默认值0000-00-00 00:00:00 php直接取出,strtotime返回fasle
timestamp
1、允许为空值,但是不可以自定义值,所以为空值时没有任何意义。
2、默认值为CURRENT_TIMESTAMP(),其实也就是当前的系统时间。
3、数版据库会自动修改其值,所以在插入记录时不需要指定timestamp字段的名称和timestamp字段的值,你只需要在设计表的时候添加一个权timestamp字段即可,插入后该字段的值会自动变为当前系统时间。
4、以后任何时间修改表中的记录时,对应记录的timestamp值会自动被更新为当前的系统时间。
「三年博客,如果觉得我的文章对您有用,请帮助本站成长」
共有 0 - Mysql 默认值