记录编译 mysql C and C++ connector 和简单访问数据库.

环境: vs2012,  mysql 5.6.13, 基于x64

0. 软件包

mysql http://dev.mysql.com/downloads/mysql/

c connector  http://dev.mysql.com/downloads/connector/c/

c++ connector依赖C connector, mysql的binary里面有编译好的C connector lib, 如果你用的编译器和mysql 一样, 那么不用重新编译

c++ connector http://dev.mysql.com/downloads/connector/cpp/

boost http://sourceforge.net/projects/boost/files/boost/1.54.0/

c++ Connector 依赖boost. 本来还尝试过vs2013, 但是boost1.54在vs2013 preview下编译有问题, 我没有试低版本的boost.

cmake http://www.cmake.org/cmake/resources/software.html

mysql的project是基于cmake. cmake可以生成vc project, 使用起来挺方便

1. 环境bat vs2012x64env.bat

call "C:\Program Files (x86)\Microsoft Visual Studio 11.0\VC\vcvarsall.bat" amd64
set PATH=%PATH%;D:\mybin\cmake-2.8.11.1-win32-x86\bin
set MYSQL_DIR=D:\mybin\mysql-5.6.13-winx64
set BOOST_ROOT=D:\mybin\boost_1_54_0
cmd /K

2. Generate vc project

C connector
cmake -G "Visual Studio 11 Win64"
build project libmysql, 只需要一个lib, 不用编译所有, debug模式下, 自带trace

C++ connector

如果想要打开trace, 加-DMYSQLCPPCONN_TRACE_ENABLE:BOOL=1, 实际还没有结束, 大概是cmake生成project的错误, 需要手动添加预定义宏 CPPCONN_TRACE_ENABLED 
cmake -DMYSQLCPPCONN_TRACE_ENABLE:BOOL=1 -G "Visual Studio 11 Win64"
build project mysqlcppconn

把头文件copy在mysql下, 方便些, 不是必须
copy D:\mybin\mysql-connector-c++-1.1.3\cppconn  D:\mybin\mysql-5.6.13-winx64\include\cppconn

3.Demo, 贴代码了

#include <iostream>

#include <memory>
#include <string>
#include <cppconn\driver.h>
#include <cppconn\exception.h>
#include <cppconn\resultset.h>
#include <cppconn\statement.h>
#include <cppconn\prepared_statement.h>

static const char*  g_sqltrance = "";//"d:t:O,client.trace";
static const int    g_enable_debug_trace = 0;

int main()
try
{

std::cout << "connect db start ... \n";
    auto driver = get_driver_instance();

std::unique_ptr<sql::Connection> con(driver->connect("tcp://127.0.0.1:3306", "root", ""));
    con->setClientOption("libmysql_debug",  g_sqltrance);
    con->setClientOption("clientTrace",    &g_enable_debug_trace);
    con->setSchema("test");

// create table
    std::unique_ptr<sql::Statement> stmt(con->createStatement());
    stmt->execute("drop table if exists test");
    stmt->execute("create table test(id int, label char(1))");

// insert
    stmt->execute("insert into test(id, label) values (1, 'a')");
    stmt->execute("insert into test(id, label) values (2, 'b')");
    stmt->execute("insert into test(id, label) values (3, 'c')");

// update
    stmt->executeUpdate("update test set label='e' where id=2");

// prepared statement
    std::unique_ptr<sql::PreparedStatement> prep_stmt(con->prepareStatement("insert into test(id, label) values(?, ?)"));
    size_t n = 5;
    while (n++ < 30)
    {
        prep_stmt->setInt(1, n);
        prep_stmt->setString(2, sql::SQLString(std::string(1, 'A' + n)));
        prep_stmt->execute();
    }

// query
    std::unique_ptr<sql::ResultSet> res(stmt->executeQuery("select id, label from test order by id asc"));
    while (res->next())
    {
        std::cout << "id = " << res->getInt(1) << "  label = " << res->getString("label") << "\n";
    }

return 0;
}
catch (sql::SQLException & e)
{
    std::cout << "SQLException : \n    "
              << e.what() 
              << "\n    ErrorCode " << e.getErrorCode() << " "
              << "\n    SQLState " << e.getSQLState() << "\n";
}
catch (...)
{
    std::cout << "uncatch exception\n";
}

4. 如果想导入sample数据库

http://dev.mysql.com/doc/index-other.htmldownload world database InnoDB version
mysql -u root
create database world;
use world;
source c:\world_innodb.sqlshow tables;

编译和使用 MySQL C++ Connector的更多相关文章

  1. Linux下MySQL c++ connector示例

    最近在学习数据库的内容,起先是在windows下用mysql c++ connector进行编程,之所以选用c++而不是c的api,主要是考虑到c++ connector是按照JDBC的api进行实现 ...

  2. 转载:Centos7 从零编译Nginx+PHP+MySql 二

    序言 这次玩次狠得.除了编译器使用yum安装,其他全部手动编译.哼~ 看似就Nginx.PHP.MySql三个东东,但是它们太尼玛依赖别人了. 没办法,想用它们就得老老实实给它们提供想要的东西. 首先 ...

  3. 转载:Centos7 从零编译Nginx+PHP+MySql 序言 一

    这次玩次狠得.除了编译器使用yum安装,其他全部手动编译.哼~ 看似就Nginx.PHP.MySql三个东东,但是它们太尼玛依赖别人了. 没办法,想用它们就得老老实实给它们提供想要的东西. 首先的一些 ...

  4. [原创]Centos7 从零编译Nginx+PHP+MySql

    序言 这次玩次狠得.除了编译器使用yum安装,其他全部手动编译.哼~ 看似就Nginx.PHP.MySql三个东东,但是它们太尼玛依赖别人了. 没办法,想用它们就得老老实实给它们提供想要的东西. 首先 ...

  5. CentOS下PHP7的编译安装,MySQL的支持和一些问题的解决

    最近试了一下PHP7,在编译和支持MySQL上都遇到一些问题,相信不少同学也同样遇到,所以在这里聊一下这个过程.简单来讲编译PHP7只需要3步: 1../buildconf --force 2../c ...

  6. mysql ODBC connector相关问题

    mysql ODBC connector我安装了,怎么就不成功了 进到命令行,运行下边的:C:\>cd \windows\SysWOW64 C:\Windows\SysWOW64>odbc ...

  7. CentOS 6.0最小化编译安装Nginx+MySQL+PHP+Zend

    http://www.osyunwei.com/archives/235.html 引言: 操作系统:CentOS 6.0 32位         下载地址:http://mirrors.163.co ...

  8. CentOS6.6 32位 Minimal版本纯编译安装Nginx Mysql PHP Memcached

    声明:部分编译指令在博客编辑器里好像被处理了,如双横线变成单横线了等等,于是在本地生成了一个pdf版本,在下面地址可以下载. LNMP+Memcached CentOS是红帽发行的免费的稳定Linux ...

  9. windows下编译qt的mysql驱动

    windows下编译qt的mysql驱动cd %QTDIR%\src\plugins\sqldrivers\mysqlqmake –o Makefile INCLUDEPATH+="C:\M ...

随机推荐

  1. Python与Django的时区问题

    在编码中牵扯到时间问题的时候,总是容易被时区问题搞混,一直以来,都是反复试验应付过去,今天终于搞清楚了个中缘由,一个心结也得以化解. Python 的时区问题 datetime.today() / d ...

  2. 详解Python中的__init__和__new__(静态方法)

    一.__init__ 方法是什么? 使用Python写过面向对象的代码的同学,可能对 __init__ 方法已经非常熟悉了,__init__ 方法通常用在初始化一个类实例的时候.例如: #-*- co ...

  3. SDOI 2017 Round2 滚粗了

    没进省队qwq 技不如人,甘拜下风

  4. [LOJ2542][PKUWC2018]随机游走(MinMax容斥+树形DP)

    MinMax容斥将问题转化为求x到S中任意点的最小时间. 树形DP,直接求概率比较困难,考虑只求系数.最后由于x节点作为树根无父亲,所以求出的第二个系数就是答案. https://blog.csdn. ...

  5. 【二分】【动态规划】Gym - 101156E - Longest Increasing Subsequences

    求最长上升子序列方案数. 转载自:http://blog.csdn.net/u013445530/article/details/47958617,如造成不便,请博主联系我. 数组A包含N个整数(可能 ...

  6. 【Floyd(并非水题orz)】BZOJ4093-[Usaco2013 Dec]Vacation Planning

    最近刷水太多标注一下防止它淹没在silver的水题中……我成为了本题,第一个T掉的人QAQ [题目大意] Bovinia设计了连接N (1 < = N < = 20,000)个农场的航班. ...

  7. 利用arpspoof探取账户密码

    ---恢复内容开始--- > /proc/sys/net/ipv4/ip_forward 首先在kali里开启IP转发功能 arpspoof -t 被害人ip 网关ip -i eth0 例如 再 ...

  8. opencv第一课 打开一个图片

    #include<stdio.h>#include<stdlib.h>#include<opencv2\opencv.hpp>#include<iostrea ...

  9. Perforce-Server迁移

    Author: JinDate: 20140827System: Windows 2008 R2 从Windows 2008 R2迁移到Windows 2008 R2 linux版本迁移官方文档htt ...

  10. Windows 7安装超级终端连接COM口设备

    Windows 7已经没有超级终端,只能用投机取巧的方式实现. 1.先配置电话 随便填写信息,然后点击确定即可. 2.下载这个终端运行,注意:要以管理员身份运行. 链接: https://pan.ba ...