gpt4 book ai didi

sqlite - 条件约束唯一

转载 作者:行者123 更新时间:2023-12-03 17:04:50 25 4
gpt4 key购买 nike

我有下一张 table

create table use_flags3 (
id INTEGER,
flag_name VARCHAR NOT NULL,
flag_description VARCHAR NOT NULL,
flag_type_id INTEGER NOT NULL,
package_id INTEGER,
FOREIGN KEY (flag_type_id) REFERENCES use_flags_types(id),
FOREIGN KEY (package_id) REFERENCES packages(id),
PRIMARY KEY (id)
);

当 flag_type_id 等于 1 时,我需要 flag_name唯一。我试图通过下一个约束实现这一点

CONSTRAINT idx1_chk CHECK (
flag_type_id in (select id from use_flags_types where flag_type="local") or
flag_type_id in (select id from use_flags_types where flag_type="expand") or
flag_type_id in (select id from use_flags_types where flag_type="expand_hidden") or
(
flag_type_id in (select id from use_flags_types where flag_type="global") and
flag_name not in (select flag_name from use_flags)
)
)

sqlite 说“CHECK 约束中禁止的子查询”。我可以替换

flag_type_id in (select id from use_flags_types where flag_type="local")

flag_type_id = ${ID_HERE} -- id from `select id from use_flags_types where flag_type="local"`

但是我不能对约束最后一部分的第二个子部分做同样的技巧

flag_name not in (select flag_name from use_flags)

是否有机会在一个表中执行我最初想要的操作(我真的不想将这些数据拆分到 2(+) 个表中)?

//希望描述的很清楚

最佳答案

如果你有一个复杂的约束,你应该使用触发器:

http://sqlfiddle.com/#!7/2094c

CREATE TABLE use_flags3 (
id INTEGER,
flag_name VARCHAR NOT NULL,
flag_description VARCHAR NOT NULL,
flag_type_id INTEGER NOT NULL,
package_id INTEGER,
FOREIGN KEY (flag_type_id) REFERENCES use_flags_types(id),
FOREIGN KEY (package_id) REFERENCES packages(id),
PRIMARY KEY (id)
);

/* TRIGGER BEFORE UPDATE version omitted */

CREATE TRIGGER fake_unique
BEFORE INSERT ON use_flags3
FOR EACH ROW
WHEN (
EXISTS (SELECT NULL
FROM use_flags_types
WHERE flag_type IN( "local", "expand", "expand_hidden")
AND flag_type_id = id
)
OR (
EXISTS (SELECT NULL
FROM use_flags_types
WHERE flag_type="global"
AND flag_type_id = id)
AND flag_name NOT IN (SELECT flag_name FROM use_flags)
)
)
BEGIN
SELECT RAISE( ABORT, 'duplicate rows' );
END;

关于sqlite - 条件约束唯一,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10231338/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com