閱讀860 返回首頁    go 阿裏雲 go 技術社區[雲棲]


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數據庫


參考文檔:

C/C++連接MySql數據庫


最後更新:2017-04-03 08:26:14

  上一篇:go 深入分析 iBATIS 框架之係統架構與映射原理
  下一篇:go 求數組中第二最大數