继续这个问题:
PDO query updating a datetime column not in query
我的表中名为lastLoginDate的列正在自动更新,即使我准备好的语句不包含所述列。
显然,当我创建新列时,设置了一个触发器。
在使用命令SHOW CREATE TABLE table_name后,我返回了以下结果:
CREATE TABLE `users_edi` (
`username` varchar(30) NOT NULL DEFAULT '',
`fullname` varchar(50) DEFAULT NULL,
`userlevel` tinyint(1) unsigned NOT NULL,
`ipaddress` varchar(30) DEFAULT NULL,
`email` varchar(150) DEFAULT NULL,
`entrydate` datetime DEFAULT NULL,
`division` varchar(35) DEFAULT NULL,
`password` varchar(32) DEFAULT NULL,
`userid` varchar(32) DEFAULT NULL,
`timestamp` int(11) unsigned NOT NULL,
`job_title` varchar(30) DEFAULT NULL,
`dept` varchar(50) DEFAULT NULL,
`phone` varchar(11) DEFAULT NULL,
`lastLoginDate` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP, // <-- here
PRIMARY KEY (`username`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
桌子已经很久了。我刚刚创建了列,不知何故,设置了一个触发器(我猜)。
无论如何,我尝试使用以下命令将其删除:
ALTER TABLE `users_edi`
`lastLoginDate` datetime DEFAULT NULL
但我只得到以下错误:
[Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '`lastLoginDate` datetime DEFAULT NULL' at line 4
如何使用ALTER TABLE命令或任何其他命令删除此触发器?
ALTER TABLE users_edi MODIFY COLUMN lastLoginDate DATETIME DEFAULT NULL;
您可能希望在ALTER TABLE上阅读此页面:https://dev.mysql.com/doc/refman/8.0/en/alter-table.html