VC++连MySQL小记
生活随笔
收集整理的這篇文章主要介紹了
VC++连MySQL小记
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
傳說(shuō)MySQL性能很好,準(zhǔn)備測(cè)試一下,如果效果好的話就把數(shù)據(jù)庫(kù)換成MySQL.但沒(méi)想到這一弄就折騰了兩個(gè)小時(shí).唉!不過(guò)還好現(xiàn)在都解決了,恩,現(xiàn)在把前兩個(gè)小時(shí)里學(xué)到的東西記在這里,以備不時(shí)之需哈~
??????? MySQL是開(kāi)源的,網(wǎng)上很容易就下的到MySQL Dowload.我下的是WINDOWS版的,安裝很簡(jiǎn)單,這里就不多說(shuō)了,但是別忘了還得下個(gè)管理工具.MySQL不像MSSQL那樣帶有圖形界面的管理工具,圖形界面程序它只帶了重新配置MySQL的MySQLInstanceConfig.exe,剩下的就是一堆命令行程序了.說(shuō)到重新配置MySQL,我得提醒下,MySQLInstanceConfig.exe如果停在了最后一步Start Service那里報(bào)錯(cuò)的話,就從新安裝MySQL吧,無(wú)論怎么配置都過(guò)不了那步.不過(guò)具體應(yīng)該可以手工改好的,不過(guò)我沒(méi)搞懂哈,直接重裝就好了.MySQL管理工具有很多,還有PHP版的,我用的是MySQL GUI Tools 5.0,算是官方版的吧,挺好用的
??????? MySQL有提供C的API接口,當(dāng)然我就直接用的它了,因?yàn)閭髡f(shuō)它比用ADO要快一些.在MySQL的安裝目錄下你會(huì)找到include和lib文件夾(完全安裝模式下),里面分別是C接口的頭文件和庫(kù)文件,庫(kù)文件只用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ù)未聲明.
??????? 下面是我用到的MySQL函數(shù):
?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))?//?遍歷每行記錄
11?????{
12?????????for(ULONG?i=0;?i<colLen;?i++)
13?????????{
14?????????????datas?+=?row[i]???row[i]?:?"NULL";
15?????????????datas?+=?"\t";
16?????????}
17?????????datas?+=?"\n\n";
18?????}
19?????mysql_free_result(result);
20?????mysql_close(&mysql);
??????? MySQL是開(kāi)源的,網(wǎng)上很容易就下的到MySQL Dowload.我下的是WINDOWS版的,安裝很簡(jiǎn)單,這里就不多說(shuō)了,但是別忘了還得下個(gè)管理工具.MySQL不像MSSQL那樣帶有圖形界面的管理工具,圖形界面程序它只帶了重新配置MySQL的MySQLInstanceConfig.exe,剩下的就是一堆命令行程序了.說(shuō)到重新配置MySQL,我得提醒下,MySQLInstanceConfig.exe如果停在了最后一步Start Service那里報(bào)錯(cuò)的話,就從新安裝MySQL吧,無(wú)論怎么配置都過(guò)不了那步.不過(guò)具體應(yīng)該可以手工改好的,不過(guò)我沒(méi)搞懂哈,直接重裝就好了.MySQL管理工具有很多,還有PHP版的,我用的是MySQL GUI Tools 5.0,算是官方版的吧,挺好用的
??????? MySQL有提供C的API接口,當(dāng)然我就直接用的它了,因?yàn)閭髡f(shuō)它比用ADO要快一些.在MySQL的安裝目錄下你會(huì)找到include和lib文件夾(完全安裝模式下),里面分別是C接口的頭文件和庫(kù)文件,庫(kù)文件只用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ù)未聲明.
??????? 下面是我用到的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是要訪問(wèn)的數(shù)據(jù)庫(kù),unix_socket和client_flag通常為NULL就可以了.連接成功返回第一個(gè)參數(shù),否則失敗
- int 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è)試嘛~)
?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))?//?遍歷每行記錄
11?????{
12?????????for(ULONG?i=0;?i<colLen;?i++)
13?????????{
14?????????????datas?+=?row[i]???row[i]?:?"NULL";
15?????????????datas?+=?"\t";
16?????????}
17?????????datas?+=?"\n\n";
18?????}
19?????mysql_free_result(result);
20?????mysql_close(&mysql);
轉(zhuǎn)載于:https://www.cnblogs.com/Alacky/archive/2007/07/17/821724.html
與50位技術(shù)專家面對(duì)面20年技術(shù)見(jiàn)證,附贈(zèng)技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的VC++连MySQL小记的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 问路T恤
- 下一篇: file control