mysql中timestamp类型 我设置了默认值 为啥java中添加时间类型还是null 在数据库中可以

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql中timestamp类型 我设置了默认值 为啥java中添加时间类型还是null 在数据库中可以相关的知识,希望对你有一定的参考价值。

上面是手动添加的 下面几条是java生成的我不知道哪错了 求解

参考技术A 你用hibernate的话,除非你在保存的时候用java指定他的值,否则本身还是NULL , 你要么就将这个列删除,由数据库自己去管理就可以了! 参考技术B 用的hibernate?如果直接写sql的话,不写这一列,是会有默认时间的。
如果给着一些写入null,那就是null了,你用的hibernate就属于这种情况啊。
hibernate要想插入时间,只能去java中的时间,然后插入了。本回答被提问者采纳
参考技术C 是Long类型的,时间戳是一段数字

mysql 数据类型TIMESTAMP

参考技术A 在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子句,这个时间戳会自动更新,否则该列有一个默认的常量但不会自动更新。
换句话说,你可以使用当前的时间戳去初始化值和自动更新,或者是其中之一,也可以都不是。(比如,你在定义的时候可以指定自动更新,但并不初始化。)

以上是关于mysql中timestamp类型 我设置了默认值 为啥java中添加时间类型还是null 在数据库中可以的主要内容,如果未能解决你的问题,请参考以下文章

MySQL timestamp的默认值怎么设置

mysql怎么在创建表时设置默认时间为系统时间

如何设置 Mysql中的datetime的默认值

mysql中如何设置默认时间为当前时间?

MySQL中timestamp数据类型定义

MySQL中timestamp数据类型定义