首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >在设置删除限制时,可以删除引用行的SQLite

在设置删除限制时,可以删除引用行的SQLite
EN

Stack Overflow用户
提问于 2019-04-10 00:47:00
回答 1查看 125关注 0票数 0

我有一张桌子上有这样的一栏:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
FOREIGN KEY("StorageFk") REFERENCES "Storage"("StoragePk") ON DELETE RESTRICT

当我使用"DB Browser (SQLite)“时,我不能删除由这个外键引用的行,这正是我想要的。但是,当我在我的node.js应用程序中运行这个查询时:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
DELETE FROM Storage WHERE StoragePk is $1

($1是占位符)行将被删除。之后,当我打开DB浏览器时,它会通知我一些外键指向一个不存在的行。

这怎麽可能?

我的完整代码是:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
db.run('DELETE FROM Storage WHERE StoragePk is ?', storageId, function (err) {
    const changes = this.changes;
    db.close(() => {
        if (err) {
            reject(err);
        }
        else if (!changes) {
            reject(`Could not find Storage with id ${storageId}.`);
        }
        else {
            resolve('OK');
        }
    });
});

当我将其称为引用行的storageId时,这将解析为“OK”。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-10 01:35:21

每次打开sqlite数据库时,都必须使用

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
PRAGMA foreign_keys = ON

文档链接

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55608357

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文