成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

QT與數據庫連接實例

移動開發
QT與數據庫連接實例與大家分享一下,數據庫的連接的時候一般都會出現一些曉得問題,如果你也出現過問題,那么本文將會幫你解決問題。

本文介紹的是QT數據庫連接實例,首先加載驅動db=QSqlDatabase::addDatabase("QODBC","db"); // 使用odbc數據庫驅動,詳細內容請看下文。

連接數據庫需要的頭文件:

  1. #include <QSqlDatabase> 
  2. #include <QSqlQuery> 

1、連接微軟的Access

 

  1. QSqlDatabase ldb = QSqlDatabase::addDatabase("QODBC");  
  2. ldb.setDatabaseName("DRIVER={Microsoft Access Driver (*.mdb)};FIL={MS Access};DBQ=system.mdb;UID=;PWD=xiaozhuset");  
  3. bool ok = ldb.open();  
  4. //新定義一個查詢集合,并指定 鏈接關鍵字。 如果有多個連接,可以隨意指定一個你需要的。  
  5. QSqlQuery mquery=QSqlQuery::QSqlQuery(ldb);          
  6. if(ok)  
  7. {  
  8. bool isok=mquery.exec("select * from sql_set;");  
  9. if (!isok)  
  10. {  
  11. ldb.close();  
  12. return -1;  
  13. }         
  14. //這個是必須的,因為查處的結果集當前位置不在***條記錄上。  
  15. mquery.next();  
  16. QString sHostName=mquery.value(1).toString();  
  17. QString sDatabaseName=mquery.value(2).toString();  
  18. QString sUserName=mquery.value(3).toString();  
  19. QString sPassword=mquery.value(4).toString();  
  20. //清除結果集  
  21. mquery.clear();  
  22. // 如果該連接不再使用,就可以關閉。  
  23. ldb.close();  
  24. //這里是將從數據庫讀出的數據寫到一個list控件里  
  25. ui.list_out->insertItem(ui.list_out->count(),sHostName);  
  26. ui.list_out->insertItem(ui.list_out->count(),sDatabaseName);      
  27. }  
  28. else  
  29. {   
  30. // 打開本地數據庫失敗,  
  31. QMessageBox::critical(0, QObject::tr("讀取Access數據庫錯誤!"),db.lastError().text());  
  32. return -1;  
  33. }     

2、連接mssql2000 數據庫

  1. QString strDatabaseName = QString("DRIVER={SQL Server};Server=(%1);Database=%2").arg("local").arg(sDatabaseName);      
  2. db=QSqlDatabase::addDatabase("QODBC","db"); // 使用odbc數據庫驅動   
  3. db.setHostName(sHostName);  
  4. db.setPort(1433);  
  5. db.setDatabaseName(strDatabaseName); // 我們之前建立的數據庫連接關鍵字  
  6. db.setUserName(sUserName);   
  7. db.setPassword(sPassword);   
  8. bool ok = db.open(); //嘗試連接數據庫  
  9. if(ok)  
  10. {   
  11. menuset_set->dbdb=db;   // 這里用sa已經成功連上數據庫     
  12. return 0;  
  13. }  
  14. else  
  15. {   
  16. // 打開數據庫失敗,  
  17. QMessageBox::critical(0, QObject::tr("數據庫連接錯誤!"),db.lastError().text());  
  18. return -2;  
  19. }          
  20. mssql2000數據庫連接的使用和Access連接使用方法一樣。  
  21. QSqlQuery mquery=QSqlQuery::QSqlQuery(db);     
  22. bool ok1=mquery.exec("select * from CarteMenu;");  
  23. if (ok1==false)return -1;  
  24. QString menu_mkey=mquery.value(13).toString();  
  25. QString strmenu_lang=mquery.value(3).toString();  
  26. //清除結果集  
  27. mquery.clear(); 

3、連接mysql 數據庫

  1. QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); // 使用mysql數據庫驅動   
  2. db.setHostName("localhost");  
  3. db.setDatabaseName("exampledb"); // 數據庫名稱  
  4. db.setUserName("sa"); // 用戶名  
  5. db.setPassword("1"); // 密碼  
  6. bool ok = db.open(); // 嘗試連接數據庫  
  7. if(ok)  
  8. {   
  9. QSqlQuery myquery;   
  10. if(myquery.exec("select * from employeedb"))  
  11. {   
  12. int num = 0;   
  13. if(db.driver()->hasFeature(QSqlDriver::QuerySize))  
  14. {  
  15. num = myquery.size(); // 如果支持結果影響的行數,那么直接記錄下來  
  16. }  
  17. else  
  18. {  
  19. myquery.last(); //否則定位到結果***  
  20. num = myquery.at() + 1;  
  21. }  
  22. //這里添加數據庫的查詢結果處理操作  
  23. }   
  24. else // 如果查詢失敗  
  25. {   
  26. QSqlError error = myquery.lastError();  
  27. }  
  28. }  
  29. else // 打開數據庫失敗  
  30. {  

小結:QT數據庫連接實例的內容介紹完了,對于數據庫,本人覺得連接時要慎重點,好像很難連接似得,老是出錯,不顧本篇文章相信能幫你解決問題。

責任編輯:zhaolei 來源: 互聯網
相關推薦

2011-07-05 10:16:16

Qt 數據庫 SQLite

2011-07-05 14:46:34

2011-08-30 14:38:50

QT數據庫

2011-07-05 16:08:10

2011-06-27 13:49:43

Qt 數據庫 QSqlQueryM

2011-06-27 13:32:21

Qt 數據庫 QSqlQueryM

2011-06-21 15:31:04

Qt 數據庫 SQL

2010-11-29 11:47:26

連接Sybase數據庫

2011-07-05 09:54:04

2011-07-05 18:04:45

QT Mysql

2010-06-01 14:42:55

連接MySQL數據庫

2011-06-23 09:00:04

QT QODBC 數據庫

2011-07-05 18:11:13

Qt 數據庫

2011-07-05 10:03:00

Qt MYSQL 數據庫

2011-06-10 10:31:57

QT mysql linux

2011-06-27 12:56:28

2009-07-29 09:12:31

ASP.NET數據庫連

2011-07-01 10:55:25

Qt 登陸窗口 界面

2011-07-26 18:11:56

iPhone Sqlite 數據庫

2009-12-31 11:10:01

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 特黄一级| 精品国产乱码久久久久久牛牛 | 国产一区二区三区 | 婷婷色国产偷v国产偷v小说 | 亚洲精品在线看 | 日韩在线一区二区三区 | 欧美日韩国产欧美 | 羞羞视频网站在线观看 | 一级黄色毛片 | 日韩午夜在线观看 | 狠狠爱视频 | 91美女在线| 成人中文字幕av | 丁香六月激情 | 夜夜av| 欧美精品一区二区免费视频 | 91精品国产乱码久久久久久久久 | 亚洲视频一区在线播放 | 欧美精品乱码99久久影院 | 亚洲午夜精品一区二区三区他趣 | 中文字幕1区2区3区 日韩在线视频免费观看 | 国产在线91| 亚洲国产精品一区二区久久 | 国产成人精品免高潮在线观看 | 91亚洲精选 | 国产在线一区二区三区 | 国产精品久久精品 | 亚洲精品视频在线观看免费 | 久久av一区 | 黄色大片免费观看 | 欧美成人影院 | 521av网站 | 精品不卡 | 天堂在线1 | 夜夜骑首页 | 天天艹逼网 | 日韩成人精品一区二区三区 | aaa国产大片 | 一区二区三区成人 | 激情视频中文字幕 | 欧美视频在线免费 |