看起来我无法添加非空约束或删除默认约束。我想向表中添加一个日期时间列并将所有值设置为任何值(可能是 1970 年或 2000 年),但似乎我不能在没有默认值的情况下使用 not null 并且一旦添加我就无法删除默认值。那么如何我可以添加此列吗?(再次只是一个普通的日期时间不为空)
user34537
问问题
6590 次
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;
于 2010-06-12T04:13:35.977 回答