我正在使用SQLite,doesn't support将a constraint添加到现有表格中。
所以我不能做这样的事情(就像一个例子):
ALTER TABLE [Customer]
ADD CONSTRAINT specify_either_phone_or_email
CHECK (([Phone] IS NOT NULL) OR ([Email] IS NOT NULL));
此方案是否有任何变通方法?
我知道:
观
答案 0 :(得分:9)
要制作包含某些架构更改的表的副本,您必须手动创建和复制:
BEGIN;
CREATE TABLE Customer_new (
[...],
CHECK ([...])
);
INSERT INTO Customer_new SELECT * FROM Customer;
DROP TABLE Customer;
ALTER TABLE Customer_new RENAME TO Customer;
COMMIT;
要阅读架构,请在sqlite3
command-line shell中执行.schema Customer
。
这为您提供了CREATE TABLE语句,您可以编辑和执行该语句。
要更改表格,您可以使用后门。
首先,阅读实际的表定义(这与你从.schema
得到的相同):
SELECT sql FROM sqlite_master WHERE type = 'table' AND name = 'Customer';
将CHECK约束添加到该字符串,然后使用PRAGMA writable_schema=1;启用对sqlite_master
的写访问权,并将新表定义写入其中:
UPDATE sqlite_master SET sql='...' WHERE type='table' AND name='Customer';
然后重新打开数据库。
警告:这仅适用于不更改表格的磁盘格式的更改。如果您确实进行了任何更改记录格式的更改(例如添加/删除字段,或修改rowid,或添加需要内部索引的约束),那么您的数据库将会爆炸性地爆发。