衡阳派盒市场营销有限公司

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Qt學習筆記之數(shù)據(jù)庫結(jié)構(gòu)設(shè)計6

jf_78858299 ? 來源:紛紜雜談 ? 作者:CY_CHEN ? 2023-02-17 13:57 ? 次閱讀

編寫好編輯的接口函數(shù)后,在數(shù)據(jù)庫操作文件中調(diào)用:

sqlite_sqlquerymodel_edit.h

#ifndef SQLITE_SQLQUERYMODEL_EDIT_H
#define SQLITE_SQLQUERYMODEL_EDIT_H


#include 
#include 
#include "editquerymodel.h"
#include 
#include 


QT_BEGIN_NAMESPACE
namespace Ui { class sqlite_sqlquerymodel_edit; }
QT_END_NAMESPACE


class sqlite_sqlquerymodel_edit : public QWidget
{
    Q_OBJECT


public:
    sqlite_sqlquerymodel_edit(QWidget *parent = nullptr);
    ~sqlite_sqlquerymodel_edit();


private:
    Ui::sqlite_sqlquerymodel_edit *ui;
    QSqlDatabase db;
};
#endif // SQLITE_SQLQUERYMODEL_EDIT_H

sqlite_sqlquerymodel_edit.c

#include "sqlite_sqlquerymodel_edit.h"
#include "ui_sqlite_sqlquerymodel_edit.h"


sqlite_sqlquerymodel_edit::sqlite_sqlquerymodel_edit(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::sqlite_sqlquerymodel_edit)
{
    ui->setupUi(this);


    //1、根據(jù)數(shù)據(jù)庫類型來連接數(shù)據(jù)庫
    db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("compary.db");
    //2、打開數(shù)據(jù)庫
    if(!db.open())
    {
        qDebug() << "open error" << db.lastError();
    }


    //3、根據(jù)需求,創(chuàng)建數(shù)據(jù)庫所需要表
    QSqlQuery query;


    /***
     * 員工表:staff
     * 字段名有 id name age address salary
     * */
    QString sqlCreateTable = QString ("create table staff(id integer primary key autoincrement,"
                                      "name varchar(20),"
                                      "age int,"
                                      "address varchar(50),"
                                      "salary int);");
    if(!query.exec(sqlCreateTable))
    {
        qDebug() << "create table" << db.lastError();
    }


//    QString sqlInsert = QString("insert into staff(name,age,address,salary)"
//                                "values('張三',20,'廣州市天河區(qū)',12000);");
//    if(!query.exec(sqlInsert))
//    {
//        qDebug() << "Error insert into data" << db.lastError();
//    }


    //1、創(chuàng)建模型對象
    editQueryModel* model = new editQueryModel;
    model->setQuery("SELECT id,name,age,address,salary FROM staff");
    model->setHeaderData(0,Qt::Horizontal,"ID");
    model->setHeaderData(1,Qt::Horizontal,"Name");
    model->setHeaderData(2,Qt::Horizontal,"Age");
    model->setHeaderData(3,Qt::Horizontal,"Address");
    model->setHeaderData(4,Qt::Horizontal,"Salary");


    //2、創(chuàng)建表格控件
    QTableView *view = new QTableView(ui->tableView);
    view->setFixedSize(QSize(this->width(),this->height()));
    view->setModel(model);
    view->show();
}


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

運行程序,可以看到數(shù)據(jù)庫表格,然后Name所在列也是可以進行修改的。

圖片

三、QSqlTableModel實現(xiàn)數(shù)據(jù)表的讀寫

QSqlQueryModel實現(xiàn)讀寫是通過重寫虛函數(shù)實現(xiàn)的,需要創(chuàng)建模型,但是對于一般數(shù)據(jù)庫的應(yīng)用,是需要導(dǎo)出為excel來做后續(xù)的數(shù)據(jù)保存或者數(shù)據(jù)處理的,這種創(chuàng)建模型的方式導(dǎo)出excel相對QSqlTableModel來說,就沒有那么方便了,因為QSqlTableModel提供了基于單個數(shù)據(jù)表的讀寫模型,可以很方便的進行操作。

QSqlTableModel顯示數(shù)據(jù)庫:

//QSqlTableModel
model = new QSqlTableModel(this);
model->setTable("staff");
model->setEditStrategy(QSqlTableModel::OnManualSubmit);
//不顯示第二列
//model->removeColumn(1);
//查詢整張表
model->select();
ui->tableView->setModel(model);

運行程序,可以看到數(shù)據(jù)庫信息已經(jīng)顯示在Qt頁面中

圖片

整個表格的數(shù)據(jù)都是可以編輯的,但是編輯過后,在下一次運行程序時,會發(fā)現(xiàn)數(shù)據(jù)其實并沒有被修改。所以如果想要進行編輯,需要添加另外的提交修改、撤銷修改、刪除當前選定行操作。

void sqlite_sqlquerymodel_edit::on_pushButton_commit_clicked()
{
    //開啟事務(wù)
    model->database().transaction();
    if (model->submitAll())//提交所有更改
    {
        //提交事務(wù)
        model->database().commit();
    }
    else
    {
        //回滾事務(wù)
        model->database().rollback();
        QMessageBox::warning(this, tr("TableView"), tr("數(shù)據(jù)庫錯誤: %1").arg(model->lastError().text()));
    }
}


void sqlite_sqlquerymodel_edit::on_pushButton_undo_clicked()
{
    model->revertAll();
}


void sqlite_sqlquerymodel_edit::on_pushButton_delete_clicked()
{
    //獲取選中的行
    int curRow = ui->tableView->currentIndex().row();
    //刪除該行
    model->removeRow(curRow);
    int ret = QMessageBox::warning(this, tr("刪除當前行"), tr("你確定要刪除該行嗎"), QMessageBox::Yes | QMessageBox::No);
    if (ret == QMessageBox::Yes)
    {
        //刪除該行 提交到數(shù)據(jù)庫
        model->submitAll();
    }
    else
    {
        //不刪除  撤銷操作
        model->revertAll();
    }
}

編輯了表格,再點擊提交,下次運行程序時,可以看到數(shù)據(jù)已經(jīng)被修改了。如果我們編輯了表格后,又不想提交,就可以點擊撤銷按鍵,所有修改了的數(shù)據(jù)就會恢復(fù)回未編輯之前的狀態(tài)。如果想要刪除某一行數(shù)據(jù),點擊刪除選中行,就可以刪除了。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • SQL
    SQL
    +關(guān)注

    關(guān)注

    1

    文章

    775

    瀏覽量

    44254
  • 數(shù)據(jù)庫
    +關(guān)注

    關(guān)注

    7

    文章

    3848

    瀏覽量

    64692
收藏 人收藏

    評論

    相關(guān)推薦

    數(shù)據(jù)庫系統(tǒng)是什么?數(shù)據(jù)庫系統(tǒng)概念數(shù)據(jù)庫設(shè)計資料免費下載

      什么是概念結(jié)構(gòu)設(shè)計1.將需求分析得到的用戶需求抽象為信息結(jié)構(gòu)即概念模型的過程就是概念結(jié)構(gòu)設(shè)計2.概念結(jié)構(gòu)是各種數(shù)據(jù)模型的共同基礎(chǔ),它比
    發(fā)表于 09-07 14:34 ?1次下載
    <b class='flag-5'>數(shù)據(jù)庫</b>系統(tǒng)是什么?<b class='flag-5'>數(shù)據(jù)庫</b>系統(tǒng)概念<b class='flag-5'>之</b><b class='flag-5'>數(shù)據(jù)庫</b>設(shè)計資料免費下載

    如何進行數(shù)據(jù)庫設(shè)計?數(shù)據(jù)庫設(shè)計介紹和需求分析及結(jié)構(gòu)設(shè)計資料概述

    數(shù)據(jù)庫設(shè)計的任務(wù)是指根據(jù)需求研制數(shù)據(jù)庫結(jié)構(gòu)并應(yīng)用 數(shù)據(jù)庫的過程。數(shù)據(jù)庫設(shè)計內(nèi)容包括數(shù)據(jù)庫
    發(fā)表于 09-13 17:05 ?0次下載
    如何進行<b class='flag-5'>數(shù)據(jù)庫</b>設(shè)計?<b class='flag-5'>數(shù)據(jù)庫</b>設(shè)計介紹和需求分析及<b class='flag-5'>結(jié)構(gòu)設(shè)計</b>資料概述

    如何使用PowerDesigner進行數(shù)據(jù)庫靜態(tài)結(jié)構(gòu)設(shè)計?詳細資料概述

    把用戶需求抽象為概念模型即為概念結(jié)構(gòu)設(shè)計。 概念模型除了要求能反映客觀世界并且易于理解外,還要求其易于向數(shù)據(jù)模型(如關(guān)系模型)轉(zhuǎn)化。 概念模型獨立于具體的數(shù)據(jù)庫系統(tǒng),是整個數(shù)據(jù)庫設(shè)
    發(fā)表于 09-13 17:05 ?0次下載
    如何使用PowerDesigner進行<b class='flag-5'>數(shù)據(jù)庫</b>靜態(tài)<b class='flag-5'>結(jié)構(gòu)設(shè)計</b>?詳細資料概述

    數(shù)據(jù)庫系統(tǒng)如何進行設(shè)計?詳細方法資料概述

    設(shè)計。許多科學家認為數(shù)據(jù)庫設(shè)計應(yīng)分6個階段進行:需求分析、概念結(jié)構(gòu)設(shè)計、邏輯結(jié)構(gòu)設(shè)計、物理結(jié)構(gòu)設(shè)計數(shù)據(jù)
    發(fā)表于 09-26 15:15 ?12次下載
    <b class='flag-5'>數(shù)據(jù)庫</b>系統(tǒng)如何進行設(shè)計?詳細方法資料概述

    數(shù)據(jù)庫靜態(tài)結(jié)構(gòu)如何設(shè)計?詳細資料任務(wù)和方法說明

    任務(wù):實現(xiàn)數(shù)據(jù)庫設(shè)計新奧爾良方法中概念結(jié)構(gòu)設(shè)計和邏輯結(jié)構(gòu)設(shè)計
    發(fā)表于 09-27 15:32 ?1次下載
    <b class='flag-5'>數(shù)據(jù)庫</b>靜態(tài)<b class='flag-5'>結(jié)構(gòu)</b>如何設(shè)計?詳細資料任務(wù)和方法說明

    數(shù)據(jù)庫教程之如何進行數(shù)據(jù)庫設(shè)計

    本文檔的主要內(nèi)容詳細介紹的是數(shù)據(jù)庫教程之如何進行數(shù)據(jù)庫設(shè)計內(nèi)容包括了:1 數(shù)據(jù)庫設(shè)計概述 ,2 數(shù)據(jù)庫需求分析 ,3 數(shù)據(jù)庫
    發(fā)表于 10-19 10:41 ?21次下載
    <b class='flag-5'>數(shù)據(jù)庫</b>教程之如何進行<b class='flag-5'>數(shù)據(jù)庫</b>設(shè)計

    數(shù)據(jù)庫設(shè)計的七大知識點總結(jié)詳細資料免費下載

    本文檔的主要內(nèi)容詳細介紹的是數(shù)據(jù)庫設(shè)計的七大知識點總結(jié)包括了:1 數(shù)據(jù)庫設(shè)計概述2 需求分析3 概念結(jié)構(gòu)設(shè)計4 邏輯結(jié)構(gòu)設(shè)計5 數(shù)據(jù)庫的物理
    發(fā)表于 10-19 10:41 ?0次下載
    <b class='flag-5'>數(shù)據(jù)庫</b>設(shè)計的七大知識點總結(jié)詳細資料免費下載

    數(shù)據(jù)庫學習入門資料數(shù)據(jù)庫的概念結(jié)構(gòu)詳細資料概述

    什么是概念結(jié)構(gòu)設(shè)計 將需求分析得到的用戶需求抽象為信息結(jié)構(gòu)即概念模型的過程就是概念結(jié)構(gòu)設(shè)計 概念結(jié)構(gòu)是各種數(shù)據(jù)模型的共同基礎(chǔ),它比
    發(fā)表于 10-25 16:29 ?0次下載
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>學習</b>入門資料<b class='flag-5'>之</b><b class='flag-5'>數(shù)據(jù)庫</b>的概念<b class='flag-5'>結(jié)構(gòu)</b>詳細資料概述

    數(shù)據(jù)庫概念結(jié)構(gòu)是如何設(shè)計的概念結(jié)構(gòu)設(shè)計資料概述

    本文檔的主要內(nèi)容詳細介紹的是數(shù)據(jù)庫概念結(jié)構(gòu)是如何設(shè)計的概念結(jié)構(gòu)設(shè)計資料概述主要內(nèi)容包括了:1 概念結(jié)構(gòu)2 概念結(jié)構(gòu)設(shè)計的方法與步驟3
    發(fā)表于 10-26 11:49 ?22次下載
    <b class='flag-5'>數(shù)據(jù)庫</b>概念<b class='flag-5'>結(jié)構(gòu)</b>是如何設(shè)計的概念<b class='flag-5'>結(jié)構(gòu)設(shè)計</b>資料概述

    數(shù)據(jù)庫的設(shè)計概念總結(jié)

    本文檔的主要內(nèi)容詳細介紹的是數(shù)據(jù)庫的設(shè)計概念總結(jié)主要內(nèi)容包括了:1.數(shù)據(jù)庫設(shè)計概述,2.需求分析,3.概念結(jié)構(gòu)設(shè)計,4.邏輯結(jié)構(gòu)設(shè)計,5.數(shù)據(jù)庫
    發(fā)表于 01-09 17:29 ?13次下載
    <b class='flag-5'>數(shù)據(jù)庫</b>的設(shè)計概念總結(jié)

    數(shù)據(jù)庫設(shè)計開發(fā)案例教程之數(shù)據(jù)庫設(shè)計的資料介紹

    本文檔的主要內(nèi)容詳細介紹的是數(shù)據(jù)庫設(shè)計開發(fā)案例教程之數(shù)據(jù)庫設(shè)計的資料介紹主要內(nèi)容包括了:1 數(shù)據(jù)庫設(shè)計概述,2 需求分析,3 概念結(jié)構(gòu)設(shè)計,4 邏輯
    發(fā)表于 01-11 11:20 ?17次下載
    <b class='flag-5'>數(shù)據(jù)庫</b>設(shè)計開發(fā)案例教程之<b class='flag-5'>數(shù)據(jù)庫</b>設(shè)計的資料介紹

    Qt學習筆記數(shù)據(jù)庫結(jié)構(gòu)設(shè)計1

    數(shù)據(jù)庫也是應(yīng)用程序的重要部分,一個完整的應(yīng)用程序幾乎都包含數(shù)據(jù)庫。 當前主流的數(shù)據(jù)庫有DB2、MYSQL、OCI、ODBC、SQLITE、TDS、Oracle。 Sqlite是一款輕型的
    的頭像 發(fā)表于 02-17 11:25 ?824次閱讀
    <b class='flag-5'>Qt</b><b class='flag-5'>學習</b><b class='flag-5'>筆記</b><b class='flag-5'>之</b><b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>結(jié)構(gòu)設(shè)計</b>1

    Qt學習筆記數(shù)據(jù)庫結(jié)構(gòu)設(shè)計2

    數(shù)據(jù)庫也是應(yīng)用程序的重要部分,一個完整的應(yīng)用程序幾乎都包含數(shù)據(jù)庫。 當前主流的數(shù)據(jù)庫有DB2、MYSQL、OCI、ODBC、SQLITE、TDS、Oracle。 Sqlite是一款輕型的
    的頭像 發(fā)表于 02-17 11:25 ?575次閱讀
    <b class='flag-5'>Qt</b><b class='flag-5'>學習</b><b class='flag-5'>筆記</b><b class='flag-5'>之</b><b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>結(jié)構(gòu)設(shè)計</b>2

    Qt學習筆記數(shù)據(jù)庫結(jié)構(gòu)設(shè)計5

    Qt中,Qt為SQL數(shù)據(jù)庫提供支持的基本模塊。Qt SQL的API分為不同的層: ·驅(qū)動層 ·SQL API層 ·用戶接口層
    的頭像 發(fā)表于 02-17 13:56 ?837次閱讀
    <b class='flag-5'>Qt</b><b class='flag-5'>學習</b><b class='flag-5'>筆記</b><b class='flag-5'>之</b><b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>結(jié)構(gòu)設(shè)計</b>5

    Qt學習筆記數(shù)據(jù)庫結(jié)構(gòu)設(shè)計7

    Qt中,Qt為SQL數(shù)據(jù)庫提供支持的基本模塊。Qt SQL的API分為不同的層: ·驅(qū)動層 ·SQL API層 ·用戶接口層
    的頭像 發(fā)表于 02-17 13:57 ?566次閱讀
    <b class='flag-5'>Qt</b><b class='flag-5'>學習</b><b class='flag-5'>筆記</b><b class='flag-5'>之</b><b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>結(jié)構(gòu)設(shè)計</b>7
    大发888注册就送58| 高额德州扑克视频| 宽城| 百家乐官网tt娱乐平台| 百家乐赌博机有鬼吗| 大发888注册送58网站| 百家乐官网玩法的秘诀| 百家乐官网鞋| 合肥太阳城莱迪广场| 太原市| 百家乐官网筹码套装100片| 牌九百家乐的玩法技巧和规则| 琼结县| 金花百家乐官网的玩法技巧和规则| 肯博百家乐的玩法技巧和规则| 安仁县| 百家乐庄闲多少| 天鸿德州扑克游戏币| 百家乐官网设备电子路| 百家乐平注法口诀技巧| 百家乐官网机器手怎么做弊| 哈尔滨百家乐赌场| bet365贴吧| 新锦江百家乐官网娱乐场开户注册| 加多宝百家乐的玩法技巧和规则| 澳门百家乐官网加盟| 百家乐揽子打法| 皇冠透注网| 百家乐娱乐城信息| 皇冠国际现金网| 百家乐是骗人的么| 赌博技术| 娱乐城百家乐论坛| 威尼斯人娱乐| 百家乐单注技巧| 皇冠赔率| 百家乐官网平台| 尊龙代理| 百家乐半圆桌| 阿巴嘎旗| 超级百家乐2龙虎斗|