亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1123 | 回復(fù): 0
打印 上一主題 下一主題

Qt數(shù)據(jù)庫(一)簡介 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2011-12-20 09:44 |只看該作者 |倒序?yàn)g覽
聲明:本文原創(chuàng)于yafeilinux的百度博客,http://hi.baidu.com/yafeilinux 轉(zhuǎn)載請(qǐng)注明出處。

從今天開始我們學(xué)習(xí)Qt數(shù)據(jù)庫編程的內(nèi)容。

先說明:我們以后使用現(xiàn)在最新的基于Qt 4.6.2的Qt Creator 1.3.1 Windows版本,該版本是2010年2月17日發(fā)布的。

數(shù)據(jù)庫幾乎是每個(gè)較大的軟件所必須應(yīng)用的,而在Qt中也使用QtSql模塊實(shí)現(xiàn)了對(duì)數(shù)據(jù)庫的完美支持。我們?cè)赒t Creator的幫助中查找QtSql Module,其內(nèi)容如下圖:

可以看到這個(gè)模塊是一組類的集合,使用這個(gè)模塊我們需要加入頭文件#include <QtSql>,而在工程文件中需要加入一行代碼:QT += sql

這里每個(gè)類的作用在后面都有簡單的介紹,你也可以進(jìn)入其中查看其詳細(xì)內(nèi)容。下面我們先簡單的說一下QSqlDatabase類和QSqlQuery類。
QSqlDatabase類實(shí)現(xiàn)了數(shù)據(jù)庫連接的操作,現(xiàn)在Qt支持的數(shù)據(jù)庫類型有如下幾種:

而 現(xiàn)在我們使用的免費(fèi)的Qt只提供了SQLite和ODBC數(shù)據(jù)庫的驅(qū)動(dòng)(我們可以在Qt Creator安裝目錄下的qt\plugins\sqldrivers文件夾下查看),而其他數(shù)據(jù)庫的驅(qū)動(dòng)需要我們自己添加。SQLite是一個(gè)小巧的 嵌入式數(shù)據(jù)庫,關(guān)于它的介紹你可以自己在網(wǎng)上查找。
QSqlQuery類用來執(zhí)行SQL語句。(關(guān)于SQL語句:在我的教程中只會(huì)出現(xiàn)很簡單的SQL語句,你沒有相關(guān)知識(shí)也可以看懂,但是如果想進(jìn)行深入學(xué)習(xí),就需要自己學(xué)習(xí)相關(guān)知識(shí)了。)

下面我們就先利用這兩個(gè)類來實(shí)現(xiàn)最簡單的數(shù)據(jù)庫程序,其他的類我們會(huì)在以后的教程中逐個(gè)學(xué)習(xí)到。
1.新建Qt控制臺(tái)工程。

2.選擇上QtSql模塊,這樣就會(huì)自動(dòng)往工程文件中添加QT += sql 這行代碼了。

3.修改main.cpp中的內(nèi)容如下。
#include <QtCore/QCoreApplication>
#include <QtSql>
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); //添加數(shù)據(jù)庫驅(qū)動(dòng)
    db.setDatabaseName(":memory:"); //數(shù)據(jù)庫連接命名
    if(!db.open()) //打開數(shù)據(jù)庫
    {
        return false;
    }

    QSqlQuery query; //以下執(zhí)行相關(guān)QSL語句
    query.exec("create table student(id int primary key,name varchar)");
    //新建student表,id設(shè)置為主鍵,還有一個(gè)name項(xiàng)
    query.exec("insert into student values(1,'xiaogang')");
    query.exec("insert into student values(2,'xiaoming')");
    query.exec("insert into student values(3,'xiaohong')");
   
//向表中插入3條記錄
    query.exec("select id,name from student where id >= 2");
    //查找表中id >=2 的記錄的id項(xiàng)和name項(xiàng)的值
    while(query.next())       //query.next()指向查找到的第一條記錄,然后每次后移一條記錄
    {
        int ele0 = query.value(0).toInt();        //query.value(0)是id的值,將其轉(zhuǎn)換為int型
        QString ele1 =query.value(1).toString();
        qDebug() << ele0 <<ele1 ;       //輸出兩個(gè)值
    }
   
    return a.exec();
}
我們使用了SQLite數(shù)據(jù)庫,連接名為“:memory:”表示這是建立在內(nèi)存中的數(shù)據(jù)庫,也就是說該數(shù)據(jù)庫只在程序運(yùn)行期間有效。如果需要保存該數(shù)據(jù)庫文件,我們可以將它更改為實(shí)際的文件路徑。
4.最終效果如下。

5.我們可以將主函數(shù)更改如下。
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    qDebug() << "Available drivers:";
    QStringList drivers = QSqlDatabase::drivers();
    foreach(QString driver, drivers)
    qDebug() << "\t" << driver;

    return a.exec();
}
這樣運(yùn)行程序就可以顯示現(xiàn)在所有能用的數(shù)據(jù)庫驅(qū)動(dòng)了。

可以看到現(xiàn)在可用的數(shù)據(jù)庫驅(qū)動(dòng)只有三個(gè)。
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP