转载请注明出处,原文地址http://www.cnblogs.com/zenki-kong/p/4382657.html

刚开始写博客,博主还只是个大三汪,学艺不精,如有错误还请前辈指出(>^ω^<),废话不多说啦,进入正文

下一篇博客应该会讲使用mysql connector c++来让c++连接mysql,本篇是直接使用mysql api

首先交代一下开发环境,64位mysql5.6.23+VS2013+WIN7旗舰版

一开始用mysql5.7.6提示缺少binary_log_types.h,搜了整个文件夹都没这个文件,于是就用5.6吧

1.要使用mysql的api,需要mysql目录下include和lib两个文件夹的东西,如果你用的是wamp或者phpstudy,里面的mysql可能没这两个文件夹,那么去下个解压版的mysql就可以了,我用的是64位的mysql5.6.23安装版

2.这点很重要,先提前把这个说了

博主一开始就卡在这里,就说怎么编译不通过呢(ㄒoㄒ)//,各种无法解析外部符号,研究了半天,发现原因在于数据库是64位版的,而程序平台是32位的(毕竟我开发经验没多少……(>﹏<))。所以我们要先设置一下平台,如果你是32位的数据库,大概可以跳过这步。

有上角 活动解决方案平台 点新建

3.在vs2013中打开项目-属性,把include和lib两个文件夹包含进来,具体路径看个人吧,如果你是安装版,就在mysql server根目录下(我是直接安装在mysql根目录)。如果你是包含了之后再改64位/32位平台,可能要重新包含一次,所以我提前说了平台问题。

先来看看这两个文件夹有啥

然后包含进来

4.把lib文件夹里的 libmysql.dll 复制到你的项目目录中(就是放h和cpp的那里)

5.外面的事情解决完了,最后就是代码了

首先是要包含的头文件和库,听说头文件顺序交换会有问题,你们可以试试,因为我项目本身很早就包含了winsock2.h,就不试拉,我也很懒的(^。^)y-~~

#include <WinSock2.h>
#include "mysql.h"
#pragma comment(lib,"wsock32.lib")
#pragma comment(lib,"libmysql.lib")

然后就是测试用的主要代码,当然测试之前你需要建立一个表,类和函数使用之类就自行度娘查吧。。。其实也很显然易懂

定义三个变量

MYSQL mysql;
MYSQL_RES *result;
MYSQL_ROW row;

然后是数据库操作的代码

mysql_init(&mysql);
mysql_real_connect(&mysql, "localhost", "root", "root", "dnd", , NULL, );
char *sql = "select * from user";//unicode下用Cstring会很麻烦,直接用char
mysql_query(&mysql, sql);
result = mysql_store_result(&mysql);
while ((row = mysql_fetch_row(result))!=NULL)
{
ShowText(row[]);//这里是个显示的函数,控制台可以用cout
}

上面的代码,没有过多的错误检测,因为几行代码而已,有问题的话注释测测吧,可以使用

unicode下用Cstring会很麻烦,直接转换类型是不行的(只会保留第一个字符),于是查询语句就出错咯

顺便问一个问题,这句会造成内存泄漏吗(我当然是知道答案的哈,就当是考一下初学者,大神就无视吧哈)

char *sql = "select * from user";

sql="I am Zenki Kong"//那加多这一句呢?会不会造成内存泄漏?

至此,如无意外就成功了!!!

但是个人感觉使用connector连接用起来更加方便,所以写完这个博客后我已经开始着手了,如果成功我也会写博客,有兴趣的同学可以留意一下。

目前了解到C++连接mysql的方法有三种,ado、直接使用mysql api还有就是connector c++

顺便问一下路过的大神,不同的连接方式对数据库的效率有影响吗?请问哪一种效率最高?

c++连接mysql数据库(使用mysql api方式,环境VS2013+MYSQL5.6)的更多相关文章

  1. mysql数据库的十种查询方式及多表查询

    --mysql数据库的十种查询方式 -- (1)查询时起别名 SELECT id AS '编号',NAME AS '姓名',age AS '年龄' FROM student; -- (2)查询时添加常 ...

  2. ref:详解MYSQL数据库密码的加密方式及破解方法

    ref:https://blog.csdn.net/paul123456789io/article/details/53081921 MySQL数据库用户密码跟其它数据库用户密码一样,在应用系统代码中 ...

  3. Mysql数据库知识-Mysql索引总结 mysql mysql数据库 mysql函数

    mysql数据库知识-Mysql索引总结: 索引(Index)是帮助MySQL高效获取数据的数据结构. 下边是自己整理的资料与自己的学习总结,,做一个汇总. 一.真的有必要使用索引吗? 不是每一个性能 ...

  4. 【MySQL 数据库】MySQL目录

    目录 [第一章]MySQL数据概述 [第二章]MySQL数据库基于Centos7.3-部署 [MySQL解惑笔记]Centos7下卸载彻底MySQL数据库 [MySQL解惑笔记]忘记MySQL数据库密 ...

  5. CentOS7 + Python3 + Django(rest_framework) + MySQL + nginx + uwsgi 部署 API 开发环境, 记坑篇

    CentOS7 + Python3 + Django(rest_framework) + MySQL + nginx + uwsgi 部署 API 开发环境 CentOS7 + Python3 + D ...

  6. plsql 连接oracle数据库的2种方式

      plsql 连接oracle数据库的2种方式 CreationTime--2018年8月10日09点50分 Author:Marydon 方式一:配置tnsnames.ora 该文件在instan ...

  7. VC++6.0连接MySQL数据库(MySQL API)

    一.MySQL的安装   Mysql的安装去官网下载就可以...最新的是5.7版本..二.VC6.0的设置(1)打开VC6.中选0 工具栏Tools菜单下的Options选项,在Directories ...

  8. PHP连接MySQL数据库的三种方式(mysql、mysqli、pdo)

    PHP与MySQL的连接有三种API接口,分别是:PHP的MySQL扩展 .PHP的mysqli扩展 .PHP数据对象(PDO) ,下面针对以上三种连接方式做下总结,以备在不同场景下选出最优方案. P ...

  9. PHP连接MySQL数据库的几种方式

    PHP 5 及以上版本建议使用以下方式连接 MySQL : MySQLi :MySQLi 只针对 MySQL 数据库,MySQLi 还提供了 API 接口. PDO (PHP Data Objects ...

  10. php连接MySQL数据库的三种方式(mysql/mysqli/pdo)

    引言 PHP与MySQL的连接有三种API接口,分别是:PHP的MySQL扩展 .PHP的mysqli扩展 .PHP数据对象(PDO) ,下面针对以上三种连接方式做下总结,以备在不同场景下选出最优方案 ...

随机推荐

  1. inline-block样式间距

    原始问题和解决方法请参考 淘宝UED官方博客:inline-block 前世今生 布局时采用行内块display:inline-block,发现元素之间有空隙,原因是由于空白字符引起的,详细见上面链接 ...

  2. jQuery代码片段

    禁用页面右键菜单 $(document).bind('contextmenu', function(){ return false; }); 浏览器判断 $.browser.version $.bro ...

  3. 当list中有中文,打印的时候显示为字符编码的问题

    当list中有中文时,print list显示的会是字符编码,比如: 用str()当然也不行: 在不安装其他包的情况下,目前我知道的解决办法是使用decode('string_escape'),如下:

  4. 关于HTML在手机端自适应的一个问题

    在写页面的时候 一直以为是自己调节的大小,结果页面跳出来的效果完全不适应手机的尺寸和宽度 其实主要是因为head头中没有放自适应标签导致:下面就让我们来认识一下这款神器吧! 其实主要就是改掉HTML页 ...

  5. 函数:我的地盘听我的 - 零基础入门学习Python019

    函数:我的地盘听我的 让编程改变世界 Change the world by program 函数与过程 在小甲鱼另一个实践性超强的编程视频教学<零基础入门学习Delphi>中,我们谈到了 ...

  6. Scala学习笔记--枚举

    枚举 scala不用关注枚举的特别语法,取而代之的是标准库中的类, scala.Enumeration 想要创建新的枚举,只需要拓展这个类的对象即可 object Color extends Enum ...

  7. 利用Azure Redis Cache构建百万量级缓存读写

    Redis是一个非常流行的基于内存的,低延迟,高吞吐量的key/value数据存储,被广泛用于数据库缓存,session的管理,热数据高速访问,甚至作为数据库方式提高应用程序可扩展性,吞吐量,和实施处 ...

  8. sqlserver中临时表、row-number、update更新自己

    SELECT * INTO #TempStudent FROM (SELECT id, ROW_NUMBER() OVER(ORDER BY id) RowNum FROM dbo.student) ...

  9. Block(二)内存管理与其他特性

    一.block放在哪里 我们针对不同情况来讨论block的存放位置: 1.栈和堆 以下情况中的block位于堆中: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 ...

  10. 采购术语PR、PO、RFQ、RFI、SOW、BOM、JIT、VMI、MRO 是什么意思

    PO:Purchase Order Form 采购订单,公司对外使用,还有个PR: ,公司内部使用的采购申请单 PR (Purchase Requirent) 请购单,采购申请单,代表企业内部的申请需 ...