mysql报错103(解决Mysql报Invalid default value for“operate_time”错误的问题)
mysql报错103
解决Mysql报Invalid default value for“operate_time”错误的问题在数据库中执行建表语句
|
CREATE TABLE `sys_acl` ( `id` int (11) NOT NULL AUTO_INCREMENT COMMENT '权限id' , `code` varchar (20) NOT NULL DEFAULT '' COMMENT '权限码' , ` name ` varchar (20) NOT NULL DEFAULT '' COMMENT '权限名称' , `acl_module_id` int (11) NOT NULL DEFAULT '0' COMMENT '权限所在的权限模块id' , `url` varchar (100) NOT NULL DEFAULT '' COMMENT '请求的url, 可以填正则表达式' , `type` int (11) NOT NULL DEFAULT '3' COMMENT '类型,1:菜单,2:按钮,3:其他' , `status` int (11) NOT NULL DEFAULT '1' COMMENT '状态,1:正常,0:冻结' , `seq` int (11) NOT NULL DEFAULT '0' COMMENT '权限在当前模块下的顺序,由小到大' , `remark` varchar (200) DEFAULT '' COMMENT '备注' , `operator` varchar (20) NOT NULL DEFAULT '' COMMENT '操作者' , `operate_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '最后一次更新时间' , `operate_ip` varchar (20) NOT NULL DEFAULT '' COMMENT '最后一个更新者的ip地址' , PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8; |
报Invalid default value for 'operate_time'错误
查资料发现,mysql5.6以后才支持datetime类型,所以把datetime换为timestamp成功解决
datetime和timestamp区别不是特别大,主要区别有下面两点
1、两者的存储方式不一样
对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。而对于DATETIME,不做任何改变,基本上是原样输入和输出。
2、两者所能存储的时间范围不一样
timestamp所能存储的时间范围为:'1970-01-01 00:00:01.000000' 到 ‘2038-01-19 03:14:07.999999'。
datetime所能存储的时间范围为:'1000-01-01 00:00:00.000000' 到 ‘9999-12-31 23:59:59.999999'。
总结:
TIMESTAMP和DATETIME除了存储范围和存储方式不一样,没有太大区别。
当然,对于跨时区的业务,TIMESTAMP更为合适。
参考链接:MYSQL-datatime和timestamp的区别
补充:mysql 出现 "1067 - Invalid default value for 'UPDATE_TIME' " 错误提示的解决办法
由于 tmp_wrh_1 的字段UPDATE_TIME 的字段类型是 timestamp ,默认值是:'0000-00-00 00:00:00'
即:
|
`UPDATE_TIME` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '更新时间' ; |
在对这个表进行操作的时候,
如:
|
alter table tmp_wrh_1 MODIFY column BUSINESS_TYPE varchar (5) comment 'hhr-服务费提现' ; --执行失败 |
会出现错误提示: 1067 - Invalid default value for 'UPDATE_TIME'
问题分析:
因为timestamp类型取值范围:1970-01-01 00:00:00 到 2037-12-31 23:59:59,
所以必须得把字段UPDATE_TIME 的默认值修改成:1970-01-01 00:00:00 到 2037-12-31 23:59:59 之间的值,
发现 默认值必须在1970-01-01 10:00:00 以后才修改成功,不知道什么原因!
问题解决:
|
alter table tmp_wrh_1 alter column update_time drop default ; alter table tmp_wrh_1 alter column UPDATE_TIME set default '1970-01-01 10:00:00' ; alter table tmp_wrh_1 MODIFY column BUSINESS_TYPE varchar (5) comment 'hhr-服务费提现' ; --执行成功 |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/a1275302036/article/details/80278949
- mysqldump 命令详解(mysqldump你可能不知道的参数)
- mysql三种查询方式(MySQL查询学习之基础查询操作)
- mysql查看执行慢的sql(系统隐形杀手——阻塞与等待SQL)
- mysql给字段加默认值(MySQL 如何处理隐式默认值)
- mysql标签的用法(mysql 的indexof函数用法说明)
- mysql和explain哪个好(MySQL EXPLAIN输出列的详细解释)
- mysql字符类型长度限制
- mysql索引原理及使用(再有人问你MySQL索引原理,就把这篇文章甩给他!)
- mysql order by id查询变慢(MySQL不使用order by实现排名的三种思路总结)
- mysql dateformat(MySQL的DATE_FORMAT函数的使用)
- mysql表结构设计分享(MySql开发之自动同步表结构)
- mysql数据库延时监控(Mysql sql慢查询监控脚本代码实例)
- mysql主从复制如何解决延迟(MySQL 8.0.23中复制架构从节点自动故障转移的问题)
- mysql数据表怎么复制(MySQL 复制表的方法)
- SQL SERVER与MySQL数据类型的对应关系
- mysql快速创建索引(MySQL创建高性能索引的全步骤)
- 吉善缘《聚宝金蟾》金蟾招财摆件 三足全铜蟾蜍客厅店铺开业礼品(吉善缘聚宝金蟾金蟾招财摆件)
- 招财化煞神兽,金蟾变了(招财化煞神兽金蟾变了)
- 26岁杨紫的白素贞遇上24岁鞠婧祎,哪个最美(26岁杨紫的白素贞遇上24岁鞠婧祎)
- 鞠婧祎和杨紫两种风格的女生,你心里谁比较美(鞠婧祎和杨紫两种风格的女生)
- 三千年第一美女鞠婧祎出演白素贞pk杨紫,颜值胜赵雅芝王祖贤(三千年第一美女鞠婧祎出演白素贞pk杨紫)
- 成都轨道交通13号线一期工程最新进展(成都轨道交通13号线一期工程最新进展)
热门推荐
- python怎么用代码写出心形(六行python代码的爱心曲线详解)
- mysql删除表数据的语句(Mysql实现定时清空一张表的旧数据并保留几条数据推荐)
- mysql怎么设置存储记录(MySQL 的一行记录是怎么存储的?)
- docker容器基础入门认知网络篇(Docker 容器生命周期 架构 以及和VM之间的差异详解)
- 方法参数过多的解决方法
- html导航条下拉菜单代码(Html+Css+Jquery实现左侧滑动拉伸导航菜单栏的示例代码)
- html判断canvas已经绘制过了(html2canvas截图空白问题的解决)
- 腾讯云docker安装elasticsearch(docker 启动elasticsearch镜像,挂载目录后报错的解决)
- mysql数据库三种模式(MySQL数据库是如何实现XA规范的)
- 如何获取gridview隐藏列的值
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9