C連接MySQL數據庫開發之Windows環境配置及測試
一、開發環境
Win8.1 64位、VS2013、MySQL5.5.3764位
MySQL安裝目錄為:C:\Program Files\MySQL\MySQL Server 5.5
二、配置工程環境
首先創建一個控製台空項目,打開VS2013,文件--> 新建項目 --> 常規 --> 選擇“空項目”
因為我們要使用MySQL數據庫的API接口編程,所以需要將工程的附加頭文件搜索目錄和附件庫文件搜索目錄,指向MySQL安裝目錄對應的位置,下麵是我機子上mysql庫和頭文件目錄:
將VS2013工程的附加頭文件目錄和附加庫目錄指向上麵兩個目錄。1> 配置頭文件目錄打開工程配置屬性窗口--> C/C++ --> 常規 --> 附加包含目錄,把mysql的include目錄添加到附加包含目錄中,如下圖所示:
2> 配置庫文件目錄
打開工程配置窗口--> 鏈接器--> 常歸 --> 附加庫目錄,把mysql的lib目錄添加到附加庫目錄中,如下圖所示:
打開工程配置窗口--> 鏈接器--> 輸入-->附中依賴項,打libmysql.lib靜態庫添加到工程編譯依賴項,如下圖所示:
將libmysql.dll動態庫拷貝到工程的根目錄或Debug目錄下:
三、測試開發環境
#include <stdio.h> #include <stdlib.h> #include <windows.h> #include <mysql.h> void testQuery(MYSQL *mysql); // 測試查詢數據 void main() { MYSQL *mysql = NULL; /*初始化MYSQL連接句柄*/ mysql = mysql_init((MYSQL *)0); if (!mysql) { return; } /* 連接數據庫,連接成功返回conn,否則返回NULL 參數1:mysql_init初始化數據庫返回的MYSQL句柄 參數2:數據庫服務器地址 參數3:數據庫用戶名 參數4:數據庫密碼 參數5:數據庫名稱 參數6:數據庫端口,為0表示默認3306 參數7:如果unix_socket不是NULL,字符串指定套接字或應該被使用的命名管道。注意host參數決定連接的類型 參數8:通常是0 */ mysql = mysql_real_connect(mysql, "localhost","root", "root", "test", 0, NULL, 0); if (mysql) { printf("connection succellfull the database!\n"); } else { printf("connection error:%d, %s\n",mysql_errno(mysql), mysql_error(mysql)); } // 查詢數據 testQuery(mysql); // 關閉連接 mysql_close(mysql); system("pause"); } // 測試查詢 void testQuery(MYSQL *mysql) { MYSQL_ROW row; MYSQL_RES *res = NULL; MYSQL_FIELD *fields = NULL; int i, field_count; char *sql = "select * from t_user"; int flag = mysql_real_query(mysql, sql, (unsigned long)strlen(sql)); if (flag) { printf("Query error:%d, %s\n",mysql_errno(mysql), mysql_error(mysql)); return; } // 將查詢結果讀到內存當中 res = mysql_store_result(mysql); // 獲取結果集中的所有字段 fields = mysql_fetch_fields(res); // 字段數量 field_count = mysql_field_count(mysql); for (i = 0; i < field_count; i++) { printf("%s\t", fields[i].name); } printf("\n"); // 遍曆結果集的每一行數據 while (row = mysql_fetch_row(res)) { for (i = 0; i < field_count; i++) { printf("%s\t", row[i]); } printf("\n"); } }
mysql測試數據及表結構:
DROP TABLE IF EXISTS `t_user`; CREATE TABLE `t_user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(32) DEFAULT NULL, `age` int(11) DEFAULT NULL, `address` varchar(100) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8; LOCK TABLES `t_user` WRITE; INSERT INTO `t_user` VALUES (1,'zhangsan',22,'hunan'),(2,'lisi',30,'beijin'); UNLOCK TABLES;測試結果:
小結配置步聚:
1> 安裝mysql
2> 創建VS工程,配置工程頭文件(mysql.h所在目錄)和庫文件(libmysql.lib所在目錄)附加目錄,指向mysql對應的目錄
3> 將libmysql.dll動態庫拷貝到工程根目錄或Debug目錄
4> 編寫測試程序,驗證C連接Mysql數據庫
----------------------------------------------------------------------優雅的分割線------------------------------------------------------------------------------------
常見錯誤:
1、main.obj : error LNK2019: 無法解析的外部符號 mysql_init。。。。。
原因是沒有在工程當中添加libmysql.lib配置,配置庫文件目錄
2、無法啟動此程序,因為計算機中丟失libmyslq.dll。。。。
將libmysql.dll動態庫拷貝到工程的根目錄或Debug目錄下。
3、未引入windows.h頭文件,因為在windows連接mysql是通過socket方式與數據庫進行通信的
4、main.obj : error LNK2019: 無法解析的外部符號 _mysql_init@4,該符號在函數 _main 中被引用.....
數據庫位數與編譯位數不一致,導致在鏈接時mysql的庫函數找不到,比如:我的mysql是64位,提供的庫當然是64位的,如果你在VS上用32位的平台去編譯就會造成鏈接時出錯。
修改編譯平台,工程-->屬性-->配置管理器-->在解決方案的工程列表中選擇對應的項目,並將其修改成32位或64位,如果沒有就新建一個。
工程源碼下載:Windows平台C連接MySQL數據庫
參考文檔:
最後更新:2017-04-03 08:26:14