在SQLite中添加非空的DateTime列但不设置默认值?

6

我无法添加非空约束或删除默认约束。我想在表中添加一个日期时间列,并将所有值设置为任何值(可能是1970年或2000年),但似乎我不能在没有默认值的情况下使用非空约束,一旦添加了默认值,就无法删除它。那么我该如何添加这个列?(再次强调只是普通的非空日期时间)

1个回答

15

不要使用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;

编辑:现在,ALTER TABLE的官方SQLite文档警告上述过程“可能会损坏触发器、视图和外键约束中对该表的引用”。安全的替代方法是为表使用临时名称,就像这样:

CREATE TABLE NewTable (/* old cols */, NewColumn DATETIME NOT NULL);
INSERT INTO NewTable SELECT *, '2000-01-01 00:00:00' FROM YourTable;
DROP TABLE YourTable;
ALTER TABLE NewTable RENAME TO YourTable;

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接