VC++连MySQL

来源:互联网 发布:股东大会网络投票 编辑:程序博客网 时间:2024/05/18 17:00

传说MySQL性能很好,准备测试一下,如果效果好的话就把数据库换成MySQL.但没想到这一弄就折腾了两个小时.!不过还好现在都解决了,,现在把前两个小时里学到的东西记在这里,以备不时之需哈~

MySQL是开源的,网上很容易就下的到MySQL Dowload.我下的是WINDOWS版的,安装很简单,这里就不多说了,但是别忘了还得下个管理工具.MySQL不像MSSQL那样带有图形界面的管理工具,图形界面程序它只带了重新配置MySQLMySQLInstanceConfig.exe,剩下的就是一堆命令行程序了.说到重新配置MySQL,我得提醒下,MySQLInstanceConfig.exe如果停在了最后一步Start Service那里报错的话,就从新安装MySQL,无论怎么配置都过不了那步.不过具体应该可以手工改好的,不过我没搞懂哈,直接重装就好了.MySQL管理工具有很多,还有PHP版的,我用的是MySQL GUI Tools 5.0,算是官方版的吧,挺好用的

MySQL有提供CAPI接口,当然我就直接用的它了,因为传说它比用ADO要快一些.MySQL的安装目录下你会找到includelib文件夹(完全安装模式下),里面分别是C接口的头文件和库文件,库文件只用libmysql.lib就好了,头文件的话代码里只需引用mysql.h,当然编译的时候mysql.h还引用了同目录下的其它文件,所以我就把include文件夹里的所有文件都拷贝到VC++include文件夹里的,只把libmysql.lib拷贝到了VC++lib文件夹里.

我新建的是个MFC程序,因为MySQL需要网络支持,所以在MFC程序创建向导里要选上"Windows 套接字",否则编译的时候会报SOCKET相关的错误(在这里我折腾了半个小时大概 -.-|||).mysql.h必须在windows.hsockets头文件之后被引用,MFC里我就把它放到stdafx.h的最后一行了.最后别忘了在连接器参数里加上libmysql.lib的连接,否则会报错:XXX函数未声明.

下面是我用到的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_socketclient_flag通常为NULL就可以了.连接成功返回第一个参数,否则失败

·  int 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)) // 遍历每行记录

11                {

12                   for(ULONG i=0; i<colLen; i++)

13                   {

14             datas += row[i] ? row[i] : "NULL";

15                                                    datas += "/t";

}

16                                                    datas += "/n/n";

}

17                                                    mysql_free_result(result);

18                                                     mysql_close(&mysql);