鱼C论坛

 找回密码
 立即注册
查看: 1991|回复: 1

[技术交流] vs2012,c++连接mysql

[复制链接]
发表于 2014-11-26 02:30:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 〃忝書γě渎ぐ 于 2014-12-12 00:41 编辑

环境设置:
安装完mysql
vs中 vc++目录  中 包含目录 D:\DevSoft\MySQL\MySQL Server 5.5\include   这个文件夹
vc++目录 中 引用目录 D:\DevSoft\MySQL\MySQL Server 5.5\lib 这个文件夹。
  
记得把 mysql 安装目录中的include目录下的libmysql.lib   复制到工程文件夹下。
如果是32位的mysql 可以直接连。 如果是 64,需要 配置 vs x64平台,在配置管理其中,然后连。

#include "stdafx.h"
#include <Windows.h>
#include <string.h>
#include <mysql.h>
#include <iostream>
using namespace std;
int main()
{
    const char user[] = "数据库账号";         //username
    const char pswd[] = "数据库密码";         //password
    const char host[] = "localhost";    //or"127.0.0.1"
    const char table[] = "数据库空间";        //database
    unsigned int port = 3306;           //server port        
    MYSQL myCont;
    MYSQL_RES *result;
    MYSQL_ROW sql_row;
    MYSQL_FIELD *fd;
    char column[32][32];
    int res;
    mysql_init(&myCont);
    if(mysql_real_connect(&myCont,host,user,pswd,table,port,NULL,0))
    {
        cout<<"connect succeed!"<<endl;
        mysql_query(&myCont, "SET NAMES GBK"); //设置编码格式,否则在cmd下无法显示中文
        res=mysql_query(&myCont,"select * from student");//查询
        if(!res)
        {
            result=mysql_store_result(&myCont);//保存查询到的数据到result
            if(result)
            {
                int i,j;
                cout<<"number of result: "<<(unsigned long)mysql_num_rows(result)<<endl;
                for(i=0;fd=mysql_fetch_field(result);i++)//获取列名
                {
                    strcpy_s(column[i],fd->name);
                }
                j=mysql_num_fields(result);
                for(i=0;i<j;i++)
                {
                    printf("%s\t",column[i]);
                }
                printf("\n");
                while(sql_row=mysql_fetch_row(result))//获取具体的数据
                {
                    for(i=0;i<j;i++)
                    {
                        printf("%s\n",sql_row);
                    }
                    printf("\n");
                }
            }
        }
        else
        {
            cout<<"query sql failed!"<<endl;
        }
    }
    else
    {
        cout<<"connect failed!"<<endl;
    }
    if(result!=NULL) mysql_free_result(result);//释放结果资源
    mysql_close(&myCont);//断开连接
system("pause");
    return 0;
}
[/i][/i]

评分

参与人数 2荣誉 +6 鱼币 +6 贡献 +5 收起 理由
ilboyvm + 1 + 1 感谢楼主无私奉献!
Angel丶L + 5 + 5 + 5 感谢楼主无私奉献!

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-11-27 10:49:46 | 显示全部楼层
新版MySQL开始收费了,唉,不爽
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-25 10:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表