程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> VC++連MySQL中的一些小知識點

VC++連MySQL中的一些小知識點

編輯:MySQL綜合教程

此文章主要介紹的是VC++連MySQL中的一些小知識點,傳說中MySQL數據庫的性能很好,所以今天准備對其測試一下,假如效果真的很好的話就把數據庫換成MySQL.但沒想到這一弄就折騰了兩個小時.

唉!不過還好現在都解決了,恩,現在把前兩個小時裡學到的東西記在這裡,以備不時之需哈~

MySQL是開源的,網上很容易就下的到MySQL Dowload.我下的是WINDOWS版的,安裝很簡單,這裡就不多說了,但是別忘了還得下個管理工具.MySQL不像MSSQL那樣帶有圖形界面的管理工具,圖形界面程序它只帶了重新配置MySQL的MySQLInstanceConfig.exe,

剩下的就是一堆命令行程序了.說到重新配置MySQL,我得提醒下,MySQLInstanceConfig.exe如果停在了最後一步Start Service那裡報錯的話,就從新安裝MySQL吧,無論怎麼配置都過不了那步.不過具體應該可以手工改好的,不過我沒搞懂哈,直接重裝就好了.MySQL管理工具有很多,還有PHP版的,我用的是MySQL GUI Tools 5.0,算是官方版的吧,挺好用的

MySQL有提供C的API接口,當然我就直接用的它了,因為傳說它比用ADO要快一些.在MySQL的安裝目錄下你會找到include和lib文件夾(完全安裝模式下),裡面分別是C接口的頭文件和庫文件,庫文件只用libmysql.lib就好了,頭文件的話代碼裡只需引用mysql.h,

當然編譯的時候mysql.h還引用了同目錄下的其它文件,所以我就把include文件夾裡的所有文件都拷貝到VC++的include文件夾裡的,只把libmysql.lib拷貝到了VC++的lib文件夾裡.

我新建的是個MFC程序,因為MySQL需要網絡支持,所以在MFC程序創建向導裡要選上"Windows 套接字",否則編譯的時候會報SOCKET相關的錯誤(在這裡我折騰了半個小時大概 -.-|||).mysql.h必須在windows.h和sockets頭文件之後被引用,MFC裡我就把它放到stdafx.h的最後一行了.最後別忘了在連接器參數裡加上libmysql.lib的連接,否則會報錯:XXX函數未聲明.

VC++連MySQL中要用到的MySQL函數:

MYSQL* mysql_init(NULL) //初始化一個MYSQL對象,後面的操作要用到

MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const char *user, const char *passwd, const char *db, unsigned int port, const char *unix_socket, unsigned long client_flag) //建立連接,db是要訪問的數據庫,unix_socket和client_flag通常為NULL就可以了.連接成功返回第一個參數,否則失敗

nt mysql_query(MYSQL *mysql, const char *stmt_str) //執行一個查詢,成功時返回0

MYSQL_RES *mysql_store_result(MYSQL *mysql) //獲取查詢返回的結果集,失敗時返回0

unsigned int mysql_num_fields(MYSQL_RES *result) //獲取返回結果集的字段數量

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result) //獲取一行記錄,並將移動到下個記錄,返回NULL時則遍歷完了所有行或出錯.MYSQL_ROW類型是個字符串數組,下標為[0,columnLength-1]

void mysql_free_result(MYSQL_RES *result) //釋放結果集

void mysql_close(MYSQL *mysql) //關閉連接

這裡是具體代碼(寫的很粗哈~測試嘛~)

  1. MYSQL mysql;  
  2. mysql_init(&mysql);  
  3. ASSERT(mysql_real_connect(&mysql, "127.0.0.1", "alacky", "password", "Test", 3306, 0, 0));  
  4. ASSERT(mysql_query(&mysql, "SELECT * FROM maxTest") == 0);  
  5.  MYSQL_RES *result;  
  6. result = mysql_store_result(&mysql);  
  7. MYSQL_ROW row;  
  8. ULONG colLen = mysql_num_fields(result);  
  9. CString datas = "";  
  10.  while(row = mysql_fetch_row(result))  

遍歷每行記錄

  1. {  
  2. for(ULONG i=0; i<colLen; i++)   
  3. {  
  4. datas += row[i] ? row[i] : "NULL";  
  5. datas += "\t";  
  6. }  
  7. datas += "\n\n";  
  8. }  
  9. mysql_free_result(result);  
  10. mysql_close(&mysql); 

以上的相關內容就是對VC++連MySQL小記的介紹,望你能有所收獲。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved