C/C++ 连接 MySQL (VC 版)

C/C++ 连接 MySQL

1、从 mysql-noinstall-5.1.30-win32.zip 包中解压 include, lib 两个目录到
使用C:\vcprojects\mysql-5.1.30 中

2、打开 VC++2008 菜单:工具->选项->项目与解决方案->VC++目录,在"显示以下内容"列表框中选择:
包含文件,把C:\vcprojects\mysql-5.1.30\include 加到下面列表中.
库文件, 把C:\vcprojects\mysql-5.1.30\lib\debug 加到下面列表中.也可使用 opt 库。


3、在 VC++2008 中建立控制台项目 visitsql

stdafx.h 添加头文件:

#pragma once

#include "targetver.h"
#include <windows.h>
#include <iostream>
#include <mysql.h>
#include <stdio.h>
#include <tchar.h>



visitsql.cpp 添加 main 函数内容(这段代码来自网上,修改了一下):
#include "stdafx.h"

using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{

char *host = "localhost";
char *user = "root";
char *pass = "12345";
char *db = "mysql";

MYSQL *sock;
MYSQL_RES *results;
MYSQL_ROW record;
sock = mysql_init(0);
if (sock)
cout << "sock handle ok!" << endl;
else
{
cout << "sock handle failed!" << mysql_error(sock) << endl;
}

//connection
if (mysql_real_connect(sock, host, user, pass, db, 0, NULL, 0))
cout << "connection ok!" << endl;
else
{
cout << "connection fail: " << mysql_error(sock) << endl;
}
mysql_set_character_set(sock,"utf8");

//connection character set
cout << "connection character set: " << mysql_character_set_name(sock) << endl;

//wait for posibility to check system/mysql sockets
if(mysql_query(sock,"select * from user"))
{
cout<<"very good!"<<endl;
}
results=mysql_store_result(sock);
printf("主机\t用户名\n");
while(record = mysql_fetch_row(results))
{
printf("%s\t%s \n",record[0],record[1]);
}
mysql_free_result(results);
//system("PAUSE");

//closing connection
mysql_close(sock);

return EXIT_SUCCESS;
//return 0;
}


4、打开 visitsql 项目属性,链接器——输入添加:
libmysql.lib
mysqlclient.lib

根据需要,可以添加 lib\debug 中的其它 lib 文件。

5、当选择 Release 版本时,必须再次配置 visitsql 项目属性,重做第4步。
因为,Release 版没有配置这两个库。

运行后,返回结果:
sock handle ok!
connection ok!
connection character set: utf8
主机 用户名
localhost root
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值