sqlite3数据库外键的问题

        sqlite3数据库的外键默认是关闭的,使用的时候需要用以下的语句启用:

PRAGMA foreign_keys = ON;

        但是,问题在于,以后执行删除语句、插入语句或者更新,在需要外键限制的地方,都需要再次打开外键。

我在执行删除语句之前,再次执行了上面的语句,但是没有生效。不知道是不是因为qt 的QSqlQuery 的query.ecec()一次只能执行一条语句。

最近试了下,可以生效了,可能是之前创建外键的语句没写对

创建外键的语句

    QStringList sqlStrList;

    sqlStrList << "DROP TABLE IF EXISTS \"MainTable\";";

    //文件信息表
    sqlStrList << " CREATE TABLE \"MainTable\" ("
                  "\"id\" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,"
                  "\"MainID\" TEXT NOT NULL UNIQUE"
                  ");";

    sqlStrList << "DROP TABLE IF EXISTS \"SubTable\";";

    //开启外键
    sqlStrList << "PRAGMA foreign_keys = ON;";

    sqlStrList << "CREATE TABLE \"SubTable\" ("
                  "\"id\" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,"
                  "\"fk_MainID\" TEXT NOT NULL,"
                  "FOREIGN KEY(fk_MainID) REFERENCES MainTable(MainID) on delete cascade on update cascade on insert cascade"
                  ");";

使用下列语句,可以列出表格中的外键方便查看:

PRAGMA foreign_key_list(tableName);

分割线

网上搜了一下,有两个方案:

  1. 修改并重新编译sqlite3源码,使其默认开启,然后在qt中不适用默认的sqlite数据库,而使用自己编译的插件;
  2. 用触发器代替;

第一个方法看了半天,整不会,唉。。。

最后用触发器了,还挺麻烦的。。。

要写好几个触发器。参考了如下:

SQLite用触发器来替代外键约束_aisq的博客-CSDN博客

SQLite 触发器 | 菜鸟教程

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLite中,可以使用以下方法来创建主键和外键。 创建主键: - 使用`PRIMARY KEY`关键字来指定一个字段作为主键。例如:`id INTEGER PRIMARY KEY`,这将创建一个名为id的整数字段,并将其设置为主键。 创建外键: - 首先,需要在父表中创建一个主键。例如:`CREATE TABLE parent (id INTEGER PRIMARY KEY)`. - 然后,在子表中创建一个外键字段,并使用`FOREIGN KEY`关键字来指定该字段是一个外键。例如:`CREATE TABLE child (id INTEGER, parent_id INTEGER, FOREIGN KEY (parent_id) REFERENCES parent(id))`,这将创建一个名为parent_id的整数字段,并将其设置为外键,引用了父表的id字段。 - 可以使用`ON DELETE`和`ON UPDATE`子句来指定外键的级联操作。例如:`FOREIGN KEY (parent_id) REFERENCES parent(id) ON DELETE CASCADE ON UPDATE CASCADE`,这将在父表中的记录被删除或更新时,自动删除或更新子表中相应的记录。 需要注意的是,在SQLite中,默认情况下外键是关闭的,需要使用`PRAGMA foreign_keys = ON`来打开外键功能。 综上所述,以上是在SQLite中创建主键和外键的方法。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* [sqlite3 表创建后设置主外键 联合主键 外键设置](https://blog.csdn.net/weixin_47523009/article/details/118253555)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [21.8:Python如何使用SQLite数据库外键?](https://blog.csdn.net/weixin_44609920/article/details/130780654)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值