QT访问QSqlite数据库的实例
admin
2023-06-06 21:21:42
0

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自适应服务器 


访问QSqlite数据库的实例:

步骤:

1、创建Qt控制台程序。
2、在pro问价中添加QT +=sql;
3、在main.cpp中添加如下代码:


[cpp] view plain copy print?QT访问QSqlite数据库的实例QT访问QSqlite数据库的实例

  1. #include   

  2. #include   

  3. #include   

  4. #include   

  5. #include   

  6. #include   

  7. #include   

  8. #include   

  9. #include   

  10.   

  11. int main(int argc, char *argv[])  

  12. {  

  13.     QCoreApplication a(argc, argv);  

  14.   

  15.     QSqlDatabase database = QSqlDatabase::addDatabase("QSQLITE");  

  16.   

  17.     database.setDatabaseName("CashSystem.db");  

  18.   

  19.     if(database.open())  

  20.     {  

  21.         qDebug()<<"Database Opened";  

  22.   

  23.         QSqlQuery sql_query;  

  24.         QString create_sql = "create table member (id int primary key, name varchar(30), address varchar(30))"//创建数据表  

  25.         QString insert_sql = "insert into member values(?,?,?)";    //插入数据  

  26.   

  27.         QString select_all_sql = "select * from member";  

  28.   

  29.         sql_query.prepare(create_sql); //创建表  

  30.         if(!sql_query.exec()) //查看创建表是否成功  

  31.         {  

  32.             qDebug()<"Table Create failed");  

  33.             qDebug()<

  34.         }  

  35.         else  

  36.         {  

  37.             qDebug()<< "Table Created" ;  

  38.   

  39.             //插入数据  

  40.             sql_query.prepare(insert_sql);  

  41.   

  42.             QVariantList GroupIDs;  

  43.             GroupIDs.append(0);  

  44.             GroupIDs.append(1);  

  45.             GroupIDs.append(2);  

  46.   

  47.             QVariantList GroupNames;  

  48.             GroupNames.append("hsp");  

  49.             GroupNames.append("rl");  

  50.             GroupNames.append("spl");  

  51.   

  52.             QVariantList GroupAddress;  

  53.             GroupAddress.append("南充");  

  54.             GroupAddress.append("宝鸡");  

  55.             GroupAddress.append("南充");  

  56.   

  57.             sql_query.addBindValue(GroupIDs);  

  58.             sql_query.addBindValue(GroupNames);  

  59.             sql_query.addBindValue(GroupAddress);  

  60.   

  61.             if(!sql_query.execBatch())  

  62.             {  

  63.                 qDebug()<

  64.             }  

  65.             else  

  66.             {  

  67.                 qDebug()<<"插入记录成功";  

  68.             }  

  69.   

  70.             //查询所有记录  

  71.             sql_query.prepare(select_all_sql);  

  72.             if(!sql_query.exec())  

  73.             {  

  74.                 qDebug()<

  75.             }  

  76.             else  

  77.             {  

  78.                 while(sql_query.next())  

  79.                 {  

  80.                     int id = sql_query.value(0).toInt();  

  81.                     QString name = sql_query.value(1).toString();  

  82.                     QString address = sql_query.value(2).toString();  

  83.                     qDebug()<"ID:%1  Name:%2  Address:%3").arg(id).arg(name).arg(address);  

  84.                 }  

  85.             }  

  86.         }  

  87.     }  

  88.     database.close();  

  89.    // QFile::remove("CashSystem.db");  

  90.     return a.exec();  

  91. }  



4、运行截图:


QT访问QSqlite数据库的实例

5、在项目的debug文件夹下,生成了对应的.db文件,使用navicat forSqlite工具打开,显示结果如下:

QT访问QSqlite数据库的实例


相关内容

热门资讯

香江警花,即将绽放于星空之间 潮新闻客户端 记者 屠晨昕 今天(23日)上午,神舟二十三号载人飞行任务新闻发布会,给了整个香港乃至...
美官员披露美伊即将签署协议的更... △霍尔木兹海峡(资料图)据美国方面23日消息,美国和伊朗即将达成一份协议,其中包括将停火再延长60天...
现代AI系统通过图灵测试首获证... 美国加州大学圣迭戈分校科学家开展了一项实证研究,首次证明现代人工智能(AI)系统通过了图灵测试。相关...
强劲“中国心” 国产自研600... 5月23日,内蒙古锡林郭勒盟上空传来轰鸣声:由我国自主研制的600公斤推力级F406涡扇发动机,双发...
留神峪矿难获救矿工讲述:自救器... 5月22日晚7时29分,山西留神峪煤矿发生瓦斯爆炸事故,已致82人死亡。据央视新闻,事故发生后,留神...
预祝圆满成功!李家超与黎家盈视... 据凤凰卫视报道,神舟二十三号载人飞船即将发射,乘组成员包括首位来自香港的航天员黎家盈。香港特区行政长...
《给阿嬷的情书》,票房超10亿... 据网络平台数据截至5月24日,2026年度电影总票房(含预售)已突破151亿元!其中,电影《给阿嬷的...
美媒称伊朗同意放弃高浓缩铀库存 新华社华盛顿5月23日电(记者黄强 颜亮)据美国媒体23日报道,作为美国与伊朗即将达成的协议中的一个...
全自动洗衣机进水管漏水怎么办 造成全自动洗衣机进水管漏水,要根据原因寻找解决办法,1、由于洗衣机进水管使用年限过长,部分出现损坏,...
电视机闪屏一下又黑屏 问答:1、电视显示屏出现短路或损坏等问题。2、电视的信号源出现干扰。3、电视内部的小零件损坏,如屏幕...