在没有默认值的情况下将非DateTime列添加到SQLite?

时间:2010-06-12 04:05:24

标签: datetime sqlite alter-table

看起来我无法添加非空约束或删除默认约束。我想在表中添加一个日期时间列,并将所有值设置为任何值(可能是1970年或2000年),但似乎我不能使用非null而没有默认值,并且我无法删除一次添加的默认值。那么如何我可以添加此列吗? (再次只是一个普通的日期时间不为空)

1 个答案:

答案 0 :(得分:13)

创建一个包含额外列的新表,而不是使用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文档现在警告上述过程,因为它“可能会破坏触发器,视图和外键约束中对该表的引用。”安全替代方法是使用 new 表的临时名称,如下所示:

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;