从这个问题延续:
PDO查询更新DateTime列,而不是查询
我的表中的一列名为LastLogindate正在自动更新,即使我的准备好的语句不包括上述列。
显然,当我创建新列时,设置了一个触发器。
使用命令show create 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表命令或任何其他命令删除此触发器?
ALTER TABLE users_edi MODIFY COLUMN lastLoginDate DATETIME DEFAULT NULL;
您可能想在Alter表上读取此页面:https://dev.mysql.com/doc/refman/8.0/en/alter-table.html