外键未被强制执行

发布于 2024-09-05 04:57:54 字数 450 浏览 3 评论 0原文

为什么 SQLite 不强制执行以下外键约束(尽管执行良好)?我该如何加强这种关系?

CREATE TABLE User (
    UserID TEXT Unique NOT NULL PRIMARY KEY,
    FirstName TEXT NOT NULL,
    LastName TEXT NOT NULL,
    Username TEXT NOT NULL,
    Password TEXT NOT NULL,
    Email TEXT NOT NULL,
    SignupDate TEXT NOT NULL
)

CREATE TABLE Category (
    CategoryID TEXT Unique NOT NULL PRIMARY KEY,
    UserID TEXT,
    FOREIGN KEY(UserID) REFERENCES User(UserID)
)

Why is the following foreign key constraint (although executes fine) not enforced by SQLite? How can I go about enforcing the relationship?

CREATE TABLE User (
    UserID TEXT Unique NOT NULL PRIMARY KEY,
    FirstName TEXT NOT NULL,
    LastName TEXT NOT NULL,
    Username TEXT NOT NULL,
    Password TEXT NOT NULL,
    Email TEXT NOT NULL,
    SignupDate TEXT NOT NULL
)

CREATE TABLE Category (
    CategoryID TEXT Unique NOT NULL PRIMARY KEY,
    UserID TEXT,
    FOREIGN KEY(UserID) REFERENCES User(UserID)
)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

暖树树初阳… 2024-09-12 04:57:54

正如相关文档所说(在2.启用外键支持部分) ):

假设该库是用
启用外键约束,它
仍必须由
应用程序在运行时,使用
PRAGMAforeign_keys 命令。为了
示例:

<代码>sqlite> PRAGMAforeign_keys = ON;

外键约束已禁用
默认情况下(向后
兼容性),所以必须启用
每个数据库分别
单独连接。

您在相关连接中使用过 PRAGMA 吗? (假设,正如文档所说,sqlite 已正确编译,并且也是一个足够新的版本,当然可以提供外键约束强制执行)。

As the relevant docs say (in section 2. Enabling Foreign Key Support):

Assuming the library is compiled with
foreign key constraints enabled, it
must still be enabled by the
application at runtime, using the
PRAGMA foreign_keys command. For
example:

sqlite> PRAGMA foreign_keys = ON;

Foreign key constraints are disabled
by default (for backwards
compatibility), so must be enabled
separately for each database
connection separately.

Have you used that PRAGMA in the relevant connection? (Assuming, as the docs say, that sqlite is compiled appropriately, and also a recent-enough version to offer foreign key constraint enforcement, of course).

仙女 2024-09-12 04:57:54

您还可以通过嵌入连接字符串来打开外键支持:

foreign keys=True

示例:

"Data Source={DatabaseFullFilePath};Version=3;foreign keys=True;datetimeformat=CurrentCulture"

You can also turn on Foreign Key support via embedding in connectionstring:

foreign keys=True

Example:

"Data Source={DatabaseFullFilePath};Version=3;foreign keys=True;datetimeformat=CurrentCulture"
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文