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来查看,然后替换即可。

    看下效果图:

     

  • 相关阅读:
    MySQL Error--存储inode用完后报设备没有空间
    MySQL Binlog--基于ROW模式的binlog event大小限制
    MySQL Transaction--网络丢包导致长时间未提交事务
    java核心技术第四篇之JDBC第二篇
    java核心技术第三篇之JDBC第一篇
    java核心技术第二篇之数据库SQL语法
    JVM垃圾回收器原理及使用介绍
    JVM中优化指南
    MySQL常用工具、日志及读写分离
    java基础第十九篇之Xml
  • 原文地址:https://www.cnblogs.com/wenix/p/2719117.html
Copyright © 2011-2022 走看看