PDO查询更新不在查询第2部分中的日期时间列

问题描述 投票:1回答:1

继续这个问题:

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命令或任何其他命令删除此触发器?

php mysql pdo alter-table
1个回答
2
投票
ALTER TABLE users_edi MODIFY COLUMN lastLoginDate DATETIME DEFAULT NULL;

您可能希望在ALTER TABLE上阅读此页面:https://dev.mysql.com/doc/refman/8.0/en/alter-table.html

© www.soinside.com 2019 - 2024. All rights reserved.