gpt4 book ai didi

SQLite:使外键唯一

转载 作者:行者123 更新时间:2023-12-03 15:48:23 29 4
gpt4 key购买 nike

我正在为 Mac OS X 应用程序使用 SQLite 3.8.11。我的目标是创建一个表,然后在内部引用其他表中的某个字段。例如:

CREATE TABLE artist(
artistid INTEGER PRIMARY KEY,
artistname TEXT
);
CREATE TABLE track(
FOREIGN KEY(trackartist) REFERENCES artist(artistid)
);

但是,我想将 trackartist 插入到 track 中,这样每一行都将包含唯一的 trackartist 值。如果 trackartist 值已经在 track 内 - 必须忽略新值。在这种情况下我该怎么做?UPDATE OR IGNORE 命令似乎不起作用,值重复。

最佳答案

这是两个不同的问题:FOREIGN KEY 仅指定被插入的值必须存在于另一个表中,但没有指定它可以在此表中出现多少次。另一方面,UNIQUE 约束要求该值在此表中出现的次数不得超过一次。

我不确定“艺术家轨道”模型是否有意义,但让我们假设您真的想指定一位艺术家不能有多个轨道。因此,您不仅要指定 trackartist 引用 artist(artistid),还要指定它是 UNIQUE:

CREATE TABLE track(
trackname TEXT,
trackartist INTEGER UNIQUE,
FOREIGN KEY(trackartist) REFERENCES artist(artistid)
);

关于SQLite:使外键唯一,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35258269/

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