自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

VC++連MySQL中的一些小知識(shí)點(diǎn)

數(shù)據(jù)庫 MySQL
以下的文章主要介紹的是VC++連MySQL中的小知識(shí)點(diǎn),其中有對(duì)實(shí)現(xiàn)VC++連MySQL中要用到的MySQL數(shù)據(jù)庫函數(shù)的具體介紹。

 

此文章主要介紹的是VC++連MySQL中的一些小知識(shí)點(diǎn),傳說中MySQL數(shù)據(jù)庫的性能很好,所以今天準(zhǔn)備對(duì)其測(cè)試一下,假如效果真的很好的話就把數(shù)據(jù)庫換成MySQL.但沒想到這一弄就折騰了兩個(gè)小時(shí).

唉!不過還好現(xiàn)在都解決了,恩,現(xiàn)在把前兩個(gè)小時(shí)里學(xué)到的東西記在這里,以備不時(shí)之需哈~

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

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

MySQL有提供C的API接口,當(dāng)然我就直接用的它了,因?yàn)閭髡f它比用ADO要快一些.在MySQL的安裝目錄下你會(huì)找到include和lib文件夾(完全安裝模式下),里面分別是C接口的頭文件和庫文件,庫文件只用libmysql.lib就好了,頭文件的話代碼里只需引用mysql.h,

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

我新建的是個(gè)MFC程序,因?yàn)镸ySQL需要網(wǎng)絡(luò)支持,所以在MFC程序創(chuàng)建向?qū)Ю镆x上"Windows 套接字",否則編譯的時(shí)候會(huì)報(bào)SOCKET相關(guān)的錯(cuò)誤(在這里我折騰了半個(gè)小時(shí)大概 -.-|||).mysql.h必須在windows.h和sockets頭文件之后被引用,MFC里我就把它放到stdafx.h的最后一行了.最后別忘了在連接器參數(shù)里加上libmysql.lib的連接,否則會(huì)報(bào)錯(cuò):XXX函數(shù)未聲明.

VC++連MySQL中要用到的MySQL函數(shù):

MYSQL* mysql_init(NULL) //初始化一個(gè)MYSQL對(duì)象,后面的操作要用到

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是要訪問的數(shù)據(jù)庫,unix_socket和client_flag通常為NULL就可以了.連接成功返回第一個(gè)參數(shù),否則失敗

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

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

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

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result) //獲取一行記錄,并將移動(dòng)到下個(gè)記錄,返回NULL時(shí)則遍歷完了所有行或出錯(cuò).MYSQL_ROW類型是個(gè)字符串?dāng)?shù)組,下標(biāo)為[0,columnLength-1]

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

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

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

  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); 

 

以上的相關(guān)內(nèi)容就是對(duì)VC++連MySQL小記的介紹,望你能有所收獲。

【編輯推薦】

  1. Python如何對(duì)MySQL存儲(chǔ)過程進(jìn)行調(diào)用?
  2. MySQL 分頁存儲(chǔ)過程的實(shí)際操作流程與代碼
  3. MySQL數(shù)據(jù)庫權(quán)限設(shè)置的實(shí)際運(yùn)行過程
  4. MySQL 觸發(fā)器insert 的3個(gè)示例演示
  5. 用linux安裝MySQL時(shí)產(chǎn)生問題破解
責(zé)任編輯:佚名 來源: cnblogs
相關(guān)推薦

2010-05-26 17:40:14

MySQL數(shù)據(jù)庫

2009-08-05 09:22:43

C#調(diào)用VC DLL

2017-07-04 13:59:28

Android模塊化

2024-11-04 09:00:00

Java開發(fā)

2010-05-19 16:41:40

2022-03-02 08:01:31

面試前端開發(fā)

2015-06-09 14:57:27

HTML5知識(shí)點(diǎn)

2020-12-28 08:16:30

前端開發(fā)技術(shù)熱點(diǎn)

2011-07-13 11:20:55

VC++ODBC

2010-05-18 10:47:52

2015-08-27 11:16:14

ios開發(fā)技巧

2011-03-31 14:16:54

Cacti技巧

2018-11-28 14:30:09

MySQLL索引設(shè)計(jì)數(shù)據(jù)庫

2012-04-23 15:49:04

2019-11-25 14:33:59

HTTPhttpsURI

2021-12-20 10:55:05

Git命令Linux

2013-04-09 11:26:55

WindowsPhon

2009-09-17 16:41:12

C#組件編程

2020-11-25 07:43:07

Java

2016-05-30 17:31:34

Spring框架
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)