导入 SQL 时出现报错解决方法
一、导入 SQL 时出现 Invalid default value for ‘create_time’ 报错解决方法
这个错误的主要原因,是因为给了时间字段的列默认值一个 CURRENT_TIMESTAMP 默认值,而这个默认值在低版本的 MySQL 中是不支持的,因此就出现了题目中的这个报错,所以呢,把每个时间字段的默认值修改一下即可,比如:
DROP TABLE IF EXISTS `tb_config`;
CREATE TABLE `tb_config` (
`config_name` varchar(100) NOT NULL DEFAULT '' COMMENT '配置项的名称',
`config_value` varchar(200) NOT NULL DEFAULT '' COMMENT '配置项的值',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
PRIMARY KEY (`config_name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
改为
DROP TABLE IF EXISTS `tb_config`;
CREATE TABLE `tb_config` (
`config_name` varchar(100) NOT NULL DEFAULT '' COMMENT '配置项的名称',
`config_value` varchar(200) NOT NULL DEFAULT '' COMMENT '配置项的值',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL COMMENT '修改时间',
PRIMARY KEY (`config_name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
一、[Err] [Dtf] 1293 - Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_T
备份远程数据转存为sql文件,将其中一列类型Timestamp改为datetime,比如上述错误表改为:
create table 'order_master' (
'order_id' varchar(32) not null,
'buyer_name' varchar(32) not null comment '买家名字',
'buyer_phone' varchar(32) not null comment '买家电话',
'buyer_address' varchar(128) not null comment '买家地址',
'buyer_openid' varchar(64) not null comment '买家微信openid',
'order_amount' decimal(8,2) not null comment '订单总金额',
'order_status' tinyint(3) not null default '0' comment '订单状态,默认0新订单'
'pay_status' tinyint(3) not null default '0' comment '订单状态,默认0未支付'
'create_time' datetime not null comment '创建时间',
'update_time' timestamp not null default current_timestamp on update current_timestamp comment '修改时间',
primary key ('order_id'),
key 'idx_buyer_openid' ('buyer_openid')
) comment '订单表';