mysql设置datetime默认值为now

MYSQL-TIMESTAMP数据类型的默认值与自动更新问题

http://blog.csdn.net/scogeek/article/details/50378480

在mysql中timestamp数据类型是一个比较特殊的数据类型,他可以自动在你不使用程序更新情况下只要你更新了记录timestamp会自动更新时间

通常表中会有一个Create date 创建日期的字段,其它数据库均有默认值的选项。MySQL也有默认值timestamp,但在MySQL中,不仅是插入就算是修改也会更新timestamp的值!

这样一来,就不是创建日期了,当作更新日期来使用比较好!

因此在MySQL中要记录创建日期还得使用datetime 然后使用NOW() 函数完成!

1: 如果定义时DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP子句都有,列值为默认使用当前的时间戳,并且自动更新。

2: 如果不使用DEFAULT或ON UPDATE子句,那么它等同于DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP。

3: 如果只有DEFAULT CURRENT_TIMESTAMP子句,而没有ON UPDATE子句,列值默认为当前时间戳但不自动更新。

4: 如果没用DEFAULT子句,但有ON UPDATE CURRENT_TIMESTAMP子句,列默认为0并自动更新。

5: 如果有一个常量值DEFAULT,该列会有一个默认值,而且不会自动初始化为当前时间戳。如果该列还有一个ON UPDATE CURRENT_TIMESTAMP子句,这个时间戳会自动更新,否则该列有一个默认的常量但不会自动更新。

换句话说,你可以使用当前的时间戳去初始化值和自动更新,或者是其中之一,也可以都不是。(比如,你在定义的时候可以指定自动更新,但并不初始化。)

最新文章

  1. 探索DOMNode
  2. ios 实现自定义状态栏StatusBar 和 导航栏navigationBar 的状态和颜色
  3. ajax如何返回多个值
  4. 创建 kylin Module/Cube
  5. HM中字典编码分析
  6. 3.第一个python程序
  7. navigationController 之间的切换
  8. Android获取ip地址
  9. AnsiString 在 Delphi 中虽然不可用,但是,在 C++ 中可以用
  10. Spring Boot Dubbo applications.properties 配置清单
  11. 3.关于QT中的MainWindow窗口,MenuBar,ToolBar,QuickTip等方面的知识点
  12. lua的String
  13. vue.js 进行初始化遇到的关于core-js的错误@core-js/modules/es6.array.find-index]
  14. abstract class 和 interface 区别
  15. CSS 1. 选择器
  16. P3980 [NOI2008]志愿者招募
  17. 根据模板导出excel
  18. C语言 · 最大子阵
  19. 029——VUE中键盘语义修饰符
  20. bzoj 2131 免费的馅饼

热门文章

  1. Java集合框架源码(四)——Vector
  2. VS2015 update3 安装 asp.net core 失败
  3. flask的基本搭建
  4. GIT 获取指定历史版本代码
  5. C++中何时使用引用
  6. ArrayList集合的特点和几种遍历方法
  7. [转载]MyBatis mapper文件中的变量引用方式#{}与${}的差别
  8. scws分词配置
  9. 利用jQuery对li标签操作
  10. 奇异值分解 SVD 的数学解释