qt QSqlTableModel的简单使用(增、删、改、查)

复制代码
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("1.db");
    if (!db.open())
    {
        qDebug() << "Failed to connect to database:" << db.lastError().text();
        return ;
    }
    QSqlQuery query;
    query.exec("create table mytable(id int, name QString, sex QString)");

    pTableModel = new QSqlTableModel(ui->tableView, db);
    pTableModel->setEditStrategy(QSqlTableModel::OnManualSubmit);// 编辑策略
    pTableModel->setTable("mytable");
 //   pTableModel->setFilter("name = '666'");
 //   pTableModel->setSort(pTableModel->fieldIndex("id"), Qt::AscendingOrder); // 增序排序

    if (!(pTableModel->select()))
    {
        if (pTableModel->lastError().isValid())
        {
            qDebug() << "Error:" << pTableModel->lastError();
        }
    }

    pTableModel->setHeaderData(pTableModel->fieldIndex("id"), Qt::Horizontal, "工号");
    pTableModel->setHeaderData(pTableModel->fieldIndex("name"), Qt::Horizontal, "姓名");
    pTableModel->setHeaderData(pTableModel->fieldIndex("sex"), Qt::Horizontal, "性别");

    ui->tableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);
    ui->tableView->setSelectionMode(QAbstractItemView::SingleSelection);
    ui->tableView->setSelectionBehavior(QAbstractItemView::SelectItems);
    ui->tableView->setModel(pTableModel); // 设置数据模型
/*
    theSelection = new QItemSelectionModel(pTableModel); // 关联选择模型
    ui->tableView->setSelectionModel(theSelection); // 设置选择模型

    dataMapper = new QDataWidgetMapper();
    dataMapper->setModel(pTableModel); // 设置数据模型
    dataMapper->setSubmitPolicy(QDataWidgetMapper::AutoSubmit);

    dataMapper->addMapping(ui->lineEdit_ID, pTableModel->fieldIndex("id"));
    dataMapper->addMapping(ui->lineEdit_Name, pTableModel->fieldIndex("name"));
    dataMapper->addMapping(ui->lineEdit_sex, pTableModel->fieldIndex("sex"));
*/

}

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


void Widget::on_pushButton_add_clicked()
{
    // 插入记录
    QSqlRecord record = pTableModel->record();
    record.setValue("id", ui->lineEdit_id->text().toInt());
    record.setValue("name", ui->lineEdit_name->text());
    record.setValue("sex", ui->lineEdit_sex->text());
    bool ret = pTableModel->insertRecord(pTableModel->rowCount(), record); // -1 表示在表的末尾插入新记录
    if (!ret)
    {
        qDebug() << "insertRecord Error:" << pTableModel->lastError();
    }
    ret = pTableModel->submitAll();
    if (!ret)
    {
        qDebug() << "insertRecord Error:" << pTableModel->lastError();
    }
}


void Widget::on_pushButton_save_clicked()
{
    pTableModel->submitAll();
}


void Widget::on_pushButton_del_clicked()
{
    bool ret = pTableModel->removeRow(pTableModel->rowCount()-1); //删除最后一行
    if(!ret)
    {
        qDebug() << "删除数据失败";
        return;
    }
    ret = pTableModel->submitAll();
    if (!ret)
    {
        qDebug() << "insertRecord Error:" << pTableModel->lastError();
    }
}

demo下载:点击跳转

运行效果:

觉得有帮助的话,打赏一下呗。。

相关推荐
醇氧11 分钟前
【Windows】优雅启动:解析一个 Java 服务的后台启动脚本
java·开发语言·windows
MapGIS技术支持1 小时前
MapGIS Objects Java计算一个三维点到平面的距离
java·开发语言·平面·制图·mapgis
程序员zgh1 小时前
C++ 互斥锁、读写锁、原子操作、条件变量
c语言·开发语言·jvm·c++
小灰灰搞电子2 小时前
Qt 重写QRadioButton实现动态radioButton源码分享
开发语言·qt·命令模式
by__csdn2 小时前
Vue3 setup()函数终极攻略:从入门到精通
开发语言·前端·javascript·vue.js·性能优化·typescript·ecmascript
喵了meme2 小时前
C语言实战5
c语言·开发语言
廋到被风吹走2 小时前
【Java】常用设计模式及应用场景详解
java·开发语言·设计模式
Sammyyyyy3 小时前
DeepSeek v3.2 正式发布,对标 GPT-5
开发语言·人工智能·gpt·算法·servbay
Luna-player3 小时前
在前端中,<a> 标签的 href=“javascript:;“ 这个是什么意思
开发语言·前端·javascript
小草cys3 小时前
项目7-七彩天气app任务7.4.2“关于”弹窗
开发语言·前端·javascript