91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C/C++?Qt數據庫SqlRelationalTable關聯表怎么使用

發布時間:2021-12-10 10:47:16 來源:億速云 閱讀:233 作者:iii 欄目:開發技術

本篇內容介紹了“C/C++ Qt數據庫SqlRelationalTable關聯表怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

首先我們創建兩張表,一張Student表存儲學生名字以及學生課程號,另一張Departments存儲每個編號所對應的系所名稱,運行代碼完成創建。

void MainWindow::InitSQL()
{
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("./lyshark.db");
    if (!db.open())
           return;

    // 執行SQL創建表
    db.exec("DROP TABLE Student");
    db.exec("CREATE TABLE Student ("
                   "id INTEGER PRIMARY KEY AUTOINCREMENT, "
                   "name VARCHAR(40) NOT NULL, "
                   "departID INTEGER NOT NULL)"
            );

    // 逐條插入數據
    db.exec("INSERT INTO Student(name,departID) VALUES('zhangsan',10)");
    db.exec("INSERT INTO Student(name,departID) VALUES('lisi',20)");
    db.exec("INSERT INTO Student(name,departID) VALUES('wangwu',30)");
    db.exec("INSERT INTO Student(name,departID) VALUES('wangmazi',40)");

    db.exec("DROP TABLE Departments");
    db.exec("CREATE TABLE Departments("
            "departID INTEGER NOT NULL,"
            "department VARCHAR(40) NOT NULL)"
            );

    db.exec("INSERT INTO Departments(departID,department) VALUES (10,'數學學院')");
    db.exec("INSERT INTO Departments(departID,department) VALUES (20,'物理學院')");
    db.exec("INSERT INTO Departments(departID,department) VALUES (30,'計算機學院')");
    
    db.commit();
    db.close();
}

初始化后將得到兩張數據表,這兩張表通過departID相關聯,如下:

C/C++?Qt數據庫SqlRelationalTable關聯表怎么使用

創建完成后,我們在程序的構造函數直接實現綁定即可,這段代碼很簡單如下:

// https://www.cnblogs.com/lyshark
MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    InitSQL();

    // 打開數據庫
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("./lyshark.db");
    if (!db.open())
        return;

    this->setCentralWidget(ui->tableView);
    ui->tableView->setSelectionBehavior(QAbstractItemView::SelectItems);
    ui->tableView->setSelectionMode(QAbstractItemView::SingleSelection);
    ui->tableView->setAlternatingRowColors(true);

    // 打開數據表
    tabModel=new QSqlRelationalTableModel(this,DB);
    tabModel->setTable("Student");                              // 設置數據表
    tabModel->setEditStrategy(QSqlTableModel::OnManualSubmit);  // OnManualSubmit
    tabModel->setSort(0,Qt::AscendingOrder);

    tabModel->setHeaderData(0,Qt::Horizontal,"學號");
    tabModel->setHeaderData(1,Qt::Horizontal,"姓名");
    tabModel->setHeaderData(2,Qt::Horizontal,"學院");

    // 設置代碼字段的查詢關系數據表
    // 打開Departments表,關聯ID和department
    tabModel->setRelation(2,QSqlRelation("Departments","departID","department"));
    theSelection=new QItemSelectionModel(tabModel);

    ui->tableView->setModel(tabModel);
    ui->tableView->setSelectionModel(theSelection);
    ui->tableView->setItemDelegate(new QSqlRelationalDelegate(ui->tableView)); // 為關系型字段設置缺省代理組件

    tabModel->select();                                                        // 打開數據表
}

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

最終綁定效果如下圖:

C/C++?Qt數據庫SqlRelationalTable關聯表怎么使用

“C/C++ Qt數據庫SqlRelationalTable關聯表怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

澄江县| 治县。| 石狮市| 青河县| 甘孜| 渭源县| 陈巴尔虎旗| 上高县| 琼海市| 高安市| 贡山| 元阳县| 阜南县| 珲春市| 阿拉尔市| 诸城市| 定结县| 平凉市| 巴林右旗| 江门市| 凤凰县| 渝北区| 拜城县| 克什克腾旗| 湖北省| 宿松县| 博爱县| 滕州市| 闽侯县| 高安市| 达拉特旗| 兰坪| 新密市| 云和县| 通州区| 达州市| 金坛市| 盈江县| 峡江县| 鹤庆县| 海伦市|