MySQL创建表时候因多个字段使用timestamp类型而出现Invalid default value for的问题的分析与解决

MySQL创建表时候因多个字段使用timestamp类型而出现Invalid default value for的问题的分析与解决

一个表里面创建多个timestamp类型的字段时候。

CREATE TABLE  table1
	(
    user_id 	         int(10), 
    create_time 	     timestamp,	
	modify_time  		 timestamp  	
	); 

会提示错误如下。

Invalid default value for 'modify_time'

这里不会提示第一个timestamp时间戳类型,只会提示后面的timestamp类型字段的类型出现了错误,这是因为MySQL创建timestamp类型时候是默认非空的,要个赋一个当前的日期时间,即Default CURRENT_TIMESTAMP。但是由于 一个表中只能有一个字段设置为CURRENT_TIMESTAMP ,因此一个表中的多个字段都使用会默认设置CURRENT_TIMESTAMP为默认值的timestamp类型是不行的。这个可以在配置文件mysql.ini里面更改。

但是我使用的是将timestamp默认值都设为空的方法,来完成表的创建,在不影响业务的前提下,这应该是一种偷懒的方法吧。

CREATE TABLE  table1
	(
	user_id 	           int(10),
    create_time 	       timestamp  NULL,
	last_modify_time  	   timestamp  NULL,
	); 
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值