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 触发器 | 菜鸟教程


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部