Qt之操作數據庫(SQLite)


 

 
    QtSql模塊提供了與平台以及數據庫種類無關的訪問SQL數據庫的接口,這個接口由利用Qt的模型視圖結構將數據庫與用戶界面集成的一套類來支持。
    QSqlDatabase對象象征了數據庫的關聯。Qt使用驅動程序與各種數據庫的應用編程接口進行通信。Qt的桌面版(Desktop Edition)包括如下一些驅動程序:
 
 驅動程序  數據庫 
 QDB2  IBM DB2 7.1版以及更新的版本 
 QIBASE  Borland InterBase
 QMYSQL  MySql 
 QOCI  甲骨文公司(Oracle Call Interface)
 QODBC   ODBC(包括微軟公司的QSL服務)
 QPSQL   PostgreSQL的7.3版以及更高版本 
 QSQLITE  QSLite第3版 
 QSQLITE2  QSLite第2版
 QTDS   Qybase自適應服務器 
    
    由於授權的許可限制,Qt的開源版本無法提供所有的驅動程序,當配置Qt時,即可以選擇Qt本身包含的SQL驅動程序,也可以以查件的形式建立驅動程序,公共領域中不斷發展的SQLite數據庫將向Qt提供支持。
    如下討論關於Qt進行SQLite的基本操作。
 
代碼如下:
 
//添加數據庫驅動、設置數據庫名稱、數據庫登錄用戶名、密碼
QSqlDatabase database = QSqlDatabase::addDatabase("QSQLITE"); 
database.setDatabaseName("database.db");
database.setUserName("root");  
database.setPassword("123456");
 
//打開數據庫
if(!database.open())
{  
qDebug()<<database.lastError();
qFatal("failed to connect.") ;
}
else
{
//QSqlQuery類提供執行和操作的SQL語句的方法。
//可以用來執行DML(數據操作語言)語句,如SELECT、INSERT、UPDATE、DELETE, 
//以及DDL(數據定義語言)語句,例如CREATE TABLE。
//也可以用來執行那些不是標准的SQL的數據庫特定的命令。
QSqlQuery sql_query; 
 
QString create_sql = "create table student (id int primary key, name varchar(30), age int)";
QString select_max_sql = "select max(id) from student";
QString insert_sql = "insert into student values (?, ?, ?)";
QString update_sql = "update student set name = :name where id = :id";
QString select_sql = "select id, name from student";
QString select_all_sql = "select * from student";
QString delete_sql = "delete from student where id = ?";
QString clear_sql = "delete from student";
 
sql_query.prepare(create_sql);
if(!sql_query.exec())
{
qDebug()<<sql_query.lastError();
}
else
{
qDebug()<<"table created!";
}
 
//查詢最大id
int max_id = 0;
sql_query.prepare(select_max_sql);
if(!sql_query.exec())
{
qDebug()<<sql_query.lastError();
}
else
{
while(sql_query.next())
{
max_id = sql_query.value(0).toInt();
qDebug()<<QString("max id:%1").arg(max_id);
}
}
//插入數據
sql_query.prepare(insert_sql);
sql_query.addBindValue(max_id+1);
sql_query.addBindValue("name");
sql_query.addBindValue(25);
if(!sql_query.exec())
{
qDebug()<<sql_query.lastError();
}
else
{
qDebug()<<"inserted!";
}
 
//更新數據
sql_query.prepare(update_sql);
sql_query.bindValue(":name", "Qt");
sql_query.bindValue(":id", 1);
if(!sql_query.exec())
{
qDebug()<<sql_query.lastError();
}
else
{
qDebug()<<"updated!";
}
 
//查詢部分數據
if(!sql_query.exec(select_sql))
{
qDebug()<<sql_query.lastError();
}
else
{
while(sql_query.next())
{
int id = sql_query.value("id").toInt();
QString name = sql_query.value("name").toString();
 
qDebug()<<QString("id:%1    name:%2").arg(id).arg(name);
}
}
 
//查詢所有數據
sql_query.prepare(select_all_sql);
if(!sql_query.exec())
{
qDebug()<<sql_query.lastError();
}
else
{
while(sql_query.next())
{
int id = sql_query.value(0).toInt();
QString name = sql_query.value(1).toString();
int age = sql_query.value(2).toInt();
 
qDebug()<<QString("id:%1    name:%2    age:%3").arg(id).arg(name).arg(age);
}
}
 
//刪除數據
sql_query.prepare(delete_sql);
sql_query.addBindValue(max_id);
if(!sql_query.exec())
{
qDebug()<<sql_query.lastError();
}
else
{
qDebug()<<"deleted!";
}
 
//清空表
sql_query.prepare(clear_sql);
if(!sql_query.exec())
{
qDebug()<<sql_query.lastError();
}
else
{
qDebug()<<"cleared";
}
}
 
//關閉數據庫
database.close();
 
//刪除數據庫
QFile::remove("database.db");
 
可以通過一些工具對SQLite進行管理,如下:
 
Qt之操作數據庫(SQLite)
 
SQLite的管理
管理工具挺多的,這里簡單介紹幾款:
  • SQLite Manager:開放源代碼的SQLite管理工具,用來管理本地電腦上的SQLite數據庫,可以獨立運行(以XULRunner方式),也可以作為Firefox、Thunderbird、Seamonkey、Songbird、Komodo、Gecko等的插件。
  • SQLite Administrator:一個用來管理SQLite數據庫文件的圖形化工具,可進行創建、設計和管理操作。提供代碼編輯器具有自動完成和語法着色,支持中文,適合初學者。
  • SQLite Database browser:一個SQLite數據庫的輕量級GUI客戶端,基於Qt庫開發,界面清潔,操作簡單,主要是為非技術用戶創建、修改和編輯SQLite數據庫的工具,使用向導方式實現。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM