平台:windows c/c++

编译器:vs2017

项目设置:项目属性页:

1.C/C++ ->常规->附加包含目录->C:\Program Files (x86)\MySQL\MySQL Connector C 6.1\include 这里是我的目录,具体找自己安装目录下的include

2.链接器->常规->附加库目录->C:\Program Files (x86)\MySQL\MySQL Connector C 6.1\lib

3.链接器->输入->附加依赖项->libmysql.lib

配置完成。

测试代码:

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <stdlib.h>
#include "mysql.h"
#include <string>

using namespace std;

int main(int argc,char* argv[])
{
 MYSQL mysql; //必备的数据结构
 //初始化数据结构
 MYSQL* sqlinit=mysql_init(&mysql);
 if (sqlinit == NULL)
 {
  cout << "mysql init failed!" << endl;
  return -1;
 }
 //初始化数据库 int STDCALL mysql_server_init(int argc, char **argv, char **groups);
 if (0 == mysql_server_init(argc, argv, 0))
 {
  cout << "mysql_server_init succeed!" << endl;
 }
 else
 {
  cout << "mysql_server_init failed!" << endl;
  return -2;
 }
 //设置连接选项  避免中文无法处理
 // mysql_option 枚举类型
 if (0 == mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "gbk"))
 {
  cout << "mysql_options succeed!" << endl;
 }
 else
 {
  cout << "mysql_option failed!" << endl;
  return -3;
 }
 //连接数据库
 if (NULL != mysql_real_connect(&mysql, "localhost", "root", "123456", "test", 3306, NULL, 0))
 {
  cout << "mysql connect succeed" << endl;
 }
 else
 {
  cout << "mysql connect failed" << endl;
  return -4;
 }
 //strsql 用于储存Sql语句
 string strsql;
 strsql = "CREATE TABLE IF NOT EXISTS `testtable2`(";
 strsql += "`runoob_id` INT UNSIGNED AUTO_INCREMENT,";
 strsql += "`runoob_title` VARCHAR(100) NOT NULL,";
 strsql += "`runoob_author` VARCHAR(40) NOT NULL,";
 strsql += "`submission_date` DATE,";
 strsql += "PRIMARY KEY(`runoob_id`)";
 strsql += ")ENGINE = InnoDB DEFAULT CHARSET = utf8; ";
 if (0 == mysql_query(&mysql, strsql.c_str()))
 {
  cout << "mysql_query succeed!" << endl;
 }
 else
 {
  cout << "mysql_query failed!" << endl;
  return -5;
 }
 //向表中插入数据
 char buf[1024];

//strsql = "INSERT INTO testtable2 (runoob_id, runoob_title,runoob_author,submission_date)VALUES(0, 'MYSQL', 'Orcale', '2017-6-9'); ";
 sprintf(buf, "INSERT INTO testtable2 (runoob_id, runoob_title,runoob_author,submission_date)VALUES(%d, 'MYSQL', 'Orcale', '2017-6-9'); ", 0);
 if (0 == mysql_query(&mysql, buf))
 {
  cout << "mysql_query succeed!" << endl;
 }
 else
 {
  cout << "mysql_query failed!" << endl;
  return -5;
 }

//查询
 string query;
 MYSQL_RES* result = NULL;
 query = "select *from testtable1 where runoob_id=1";
 if (0 == mysql_query(&mysql, query.c_str()))
 {
  cout << "mysql_query succeed!" << endl;

result=mysql_store_result(&mysql);
  //取得并打印行数
  my_ulonglong rowcount = mysql_num_rows(result);
  cout << "row count: " << rowcount << endl;
  //取得各个字段
  unsigned int fieldcount = mysql_field_count(&mysql);
  for (unsigned int i = 0; i < fieldcount; i++)
  {
   MYSQL_FIELD* field = mysql_fetch_field_direct(result, i);
   cout << field->name << i << endl;
  }
 }
 else
 {
  cout << "mysql_query failed" << endl;
  mysql_close(&mysql);
  return -6;
 }
 //清理
 mysql_free_result(result);
 mysql_close(&mysql);
 mysql_server_end();
 system("pause");
 return 0;
}

windows下C++连接mysql的更多相关文章

  1. windows下远程连接Mysql

    使用“Ctrl + R”组合键快速打开cmd窗口,并输入“cmd”命令,打开cmd窗口. 使用“mysql -uroot -proot”命令可以连接到本地的mysql服务. 使用“use mysql” ...

  2. Windows下Qt连接MySql数据库

    1.设置环境变量,需添加如下的环境变量:      2.打开Qt Command Prompt,输入第一条命令:cd %QTDIR%\src\plugins\sqldrivers\mysql 后按回车 ...

  3. windows下搭建Apache+Mysql+PHP开发环境

    原文:windows下搭建Apache+Mysql+PHP开发环境 要求 必备知识 熟悉基本编程环境搭建. 运行环境 windows 7(64位); Apache2.2;MySQL Server 5. ...

  4. windows下如何设置mysql环境变量

    方法一: windows下如何设置mysql环境变量 关键词: mysql, Setting Environment Variables, 环境变量设置 我的电脑->属性->高级-> ...

  5. 本地windows下PHP连接远程oracle遇到的诸多问题

    任务目的:本地windows下PHP连接远程服务器下的oracle. 必须必须 确定服务器的数据库版本,如果本地的驱动和对方服务器版本不一致,会导致许多报错. 已知的oracle版本  分为 32位的 ...

  6. linux下启动mysql服务(类似于windows下net start mysql)

    1.linux系统启动方式:service mysql start.其类似于windows下net start mysql

  7. windows下plsql连接linux下的oracle数据库

    windows下plsql连接linux下的oracle数据库 经过多方查找,终于找到解决办法,特此记录下来,共享之. PL/SQL Develorper:目前未发现可以在Linux系统中安装的版本. ...

  8. Windows下安装配置MySQL

    Windows下安装配置MySQL的基本步骤 一.MySQL下载 MySQL官方下载地址https://dev.mysql.com/downloads/mysql/5.7.html#downloads ...

  9. Windows操作系统下远程连接MySQL数据库

    用Eclipse做一个后台项目,但是数据库不想放在本地电脑,于是买了一个腾讯云服务器(学生有优惠,挺便宜的),装上MySQL数据库,但是测试连接的时候,发现总是连接不是上,但是本地数据库可以连接,于是 ...

随机推荐

  1. P1265 公路修建 最小生成树

    题目描述 某国有n个城市,它们互相之间没有公路相通,因此交通十分不便.为解决这一“行路难”的问题,政府决定修建公路.修建公路的任务由各城市共同完成. 修建工程分若干轮完成.在每一轮中,每个城市选择一个 ...

  2. H5测试与PC端测试不同的点

    1.通过H5网页(非手机的返回功能)的返回功能可以返回,不会出现无法返回的情况. 2.横屏竖屏相互切换,能自适应,并且布局不会乱掉: 3.为能在不同分辨率的手机上能更好的展示,建议采用响应式设计(如: ...

  3. 一份详细的asyncio入门教程

    asyncio模块提供了使用协程构建并发应用的工具.它使用一种单线程单进程的的方式实现并发,应用的各个部分彼此合作, 可以显示的切换任务,一般会在程序阻塞I/O操作的时候发生上下文切换如等待读写文件, ...

  4. YII2 用 in查询的时候出现无结果, 删除某些值后查询有结果 提前sort数组即可

    YII2 用 in查询的时候出现无结果, 删除某些值后查询有结果, 在数组前用了一个 array_merge 合并了2个数组. 排查发现是 数组中键值没有挨着从0开始 另外没有从小到大, 没观察室哪个 ...

  5. react-native-splash-screen 插件 android 系统app崩溃问题

    问题 react-native版本 0.53.3 react-native-splash-screen版本 3.0.6 一切配置妥当后出现如下问题: 在android studio里的调试报错为and ...

  6. bootstrap_开始

    bootstrap 一个移动设备优先 UI 库,底层是用 less 写的,依赖于 jQuery. 面试点: bootstrap 的所有盒子都是怪异盒子模型(box-sizing: border-box ...

  7. 7. Buffer_包描述文件_npm常用指令_fs文件读写_模块化require的规则

    1. Buffer 一个和数组类似的对象,不同是 Buffer 是专门用来保存二进制数据的. 特点: 大小固定: 在创建时就确定了,且无法调整 性能较好: 直接对计算机的内存进行操作 每个元素大小为1 ...

  8. wordpress chronus主题 显示文章阅读数

    wordpress chronus主题 显示文章阅读数 第一步:将下面的代码拷贝到文件 /wp-content/themes/chronus/inc/template-tags.php 中 funct ...

  9. netbeans10支持php7.1-7.3

    2019年1月16日10:56:49 官方发布时间2018年12月27日 PHP支持 NetBeans 10的所有PHP支持都是由我们的NetBeans提交者 Junichi Yamamoto提供的. ...

  10. c++函数strapy

    头文件:#include <string.h> 定义函数:char *strcpy(char *dest, const char *src); 函数说明:strcpy()会将参数src 字 ...