Qt SQlite实现级联删除

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "QSqlDatabase"
#include "qdebug.h"
#include "QSqlQuery"
MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("Test.db");
    if(!db.open())
    {
        qDebug()<<"open false!";
    }

    QSqlQuery query(db);


     if(!query.exec("PRAGMA foreign_keys = ON"))//使外键功能生效
     {
         qDebug()<<"No Effect!";
     }
    // -- 创建测试主表. ID 是主键.
    query.exec("CREATE TABLE test_main ("
               "id      INT   NOT null,"
               "value   varchar(10),"
               "PRIMARY key(id)"
               ")");

    //-- 插入测试主表数据.
    query.exec("INSERT INTO test_main(id, value) VALUES (1, 'ONE')");
    query.exec("INSERT INTO test_main(id, value) VALUES (2, 'TWO')");

    //-- 创建测试子表.   (  注意,  这里要有一个 ON DELETE cascade )
    query.exec("CREATE TABLE test_sub ("
               "id      INT   PRIMARY key,"
               "main_id INT   REFERENCES  test_main(id)  ON DELETE cascade,"
               "value   varchar(10)"
               ")");

    //-- 插入测试子表数据.
    query.exec("INSERT INTO test_sub(id, main_id, value) VALUES (1, 1, 'ONEONE')");
    query.exec("INSERT INTO test_sub(id, main_id, value) VALUES (2, 2, 'TWOTWO')");

    //-- 测试删除主表.
    query.exec("DELETE FROM test_main WHERE id = 1");
}

MainWindow::~MainWindow()
{
    delete ui;
}

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值