zoukankan      html  css  js  c++  java
  • mysql connector c++与 visual studio 2012 联合使用

    软件环境:

    win8 build8200 64位版本,

    visual studio 2012,

    mysql 5.5.28,

    mysql connector c++ 1.1.1

    从官网上下载了mysql connector c++ 1.1.1以后,使用封装的类连接时出了很多令人十分蛋疼的问题。

    1.缺少sqlstring.h头文件---->下载noinstall版本,里面有这个文件。

    2.需要boost环境---->下载boost库,然后编译,然后加入头文件和库文件搜索路径到工程中。

    3.使用result->getString();崩溃。---->下面详细说明此问题。

    原因是官方提供的库文件版本与需要的库版本不匹配,提供的debug版本使用的是MT版本,在debug模式下会出现内存错误,导致crash。只是根本原因,至于加入msvcrt.lib等库文件等解决办法,毫无作用。经过试验,只能使用如下办法:

    1.下载mysql connector c++ 1.1.1 源代码,解压到非系统盘下(涉及权限问题)。

    2.下载cmake

    3.配置MYSQL_DIR指向mysql server的路径。

    4.配置BOOST_ROOT指向boost库路径。

    5.把cmake添加到PATH中。

    6.然后使用visual studio 2012 自带的命令终端进入mysql connector c++ 1.1.1解压后的目录中,不建议使用一般终端,因为可能会有环境变量没配置的情况。

    7a.输入cmake -G "Visual Studio 11 Win64".

    8a.输入devenv.com MySQLCPPCONN.sln /build Release,这样编译出来的库版本是Release版本,dll在driver/Release目录下。

    7b.输入cmake -G "Visual Studio 11 Win64" -DCMAKE_BUILD_TYPE=Debug

    8b.输入devenv.com MySQLCPPCONN.sln /build Debug,这样编译出来的库版本是Debug版本,dll在driver/Rease目录下。

    然后把相应的库拷贝到工程的Debug,Release目录下,配置工程属性中的c/c++-->Code Generation-->Runtime Library为MDd,就是Debug版,如果是MT,就是Release版本。这样上面的问题就解决了。

    PS:我的是64位环境,如果是win32的,相应的参数可以使用cmake --help来查看,然后替换即可。

    看下效果图:

     

  • 相关阅读:
    《数据通信与网络》笔记--数据链路层的成帧
    设计模式10---设计模式之原型模式(Prototype)
    Yii 控制dropdownlist / select 控件的宽度和 option 的宽度
    [置顶] 如何vs在cocos2dx项目中打印中文
    mongodb实现简单的增删改查
    北京和硅谷在创新方面的区别
    Android 解决Gallery下ScrollView滑动事件冲突
    Java 授权内幕--转载
    JAVA 上加密算法的实现用例---转载
    基于事件的 NIO 多线程服务器--转载
  • 原文地址:https://www.cnblogs.com/wenix/p/2719117.html
Copyright © 2011-2022 走看看