看起来我无法
添加非空约束或
删除默认约束.我想在表中
添加一个日期时间列,并将所有值设置为任何值(可能是1970年或2000年),但似乎我不能使用非null而没有
默认值,并且我无法
删除一次
添加的
默认值.那么如何我可以
添加此列吗? (再次只是
一个简单的日期时间不为空)
而不是使用ALTER TABLE ADD COLUMN,创建
一个具有额外列的新表,并复制旧数据.这将使您免受ALTER TABLE的限制,并允许您具有NOT NULL约束而没有
默认值.
ALTER TABLE YourTable RENAME TO OldTable;
CREATE TABLE YourTable (/* old cols */,NewColumn DATETIME NOT NULL);
INSERT INTO YourTable SELECT *,'2000-01-01 00:00:00' FROM OldTable;
DROP TABLE OldTable;