、安装MySQL

2、建立C++控制台程序,新建CPP源文件,如:sqlconn.cpp

3、工程项目中属性—C/C++--常规—附加包含目录中添加mysql安装目录中的MySQL\MySQL\MySQL Server 5.7\include

4、添加库目录C:\Program Files\MySQL\MySQL Server 5.7\lib

5、添加依赖项 libmysql.lib

6、运行平台改为X64(这不很重要,不然编译会报错)

7、源文件中stdafx.h中添加头文件winsock.h和mysql.h(下图这样编译会报错)

8、编写自己的数据库操作程序

// sqlconn.cpp : 定义控制台应用程序的入口点。

#include <stdio.h>

#include <mysql.h>

#include "stdafx.h"

int _tmain(int argc, _TCHAR* argv[])

{

MYSQL * con; //数据库对象

MYSQL_RES *res; //res结构体,用于保存查询结果

MYSQL_ROW row;

char tmp[400];

//database configuaration

char dbuser[30] = "root";

char dbpasswd[30]="root";

char dbip[30]="localhost";

char dbname[50]="test";

char tablename[50]="user";

char *query=NULL;

int x,y,rt;

unsigned int t;

int count=0;

//初始化数据库环境

con = mysql_init((MYSQL*)0);

//连接数据库

if(con!=NULL&&mysql_real_connect(con,dbip,dbuser,dbpasswd,dbname,3306,NULL,0))

{

//选择要操作的数据库

if(!mysql_select_db(con,dbname))

{

printf("select success the database!\n");

con->reconnect=1;

//执行sql语句设置编码为gbk

query="set names \'gbk\'";

rt=mysql_real_query(con,query,strlen(query));

//Sql语句执行为0则成功

if(rt){

printf("Error making query:%s!\n",mysql_error(con));

}

else{

printf("query %s success!\n",query);

}

}

}

else{

MessageBoxA(NULL,"Unable to connect the database,check your configuration!","",NULL);

}

//数据库中插入记录

//sql语句

sprintf_s(tmp,"insert into user values(null,'liujie2')");

//执行

rt = mysql_real_query(con,tmp,strlen(tmp));

if(rt){

printf("Error making query:%s!\n",mysql_error(con));

}

else{

printf("%s executed!\n",tmp);

}

//给表中插入数据

sprintf_s(tmp,"select * from %s",tablename);

//执行

rt = mysql_real_query(con,tmp,strlen(tmp));

if(rt){

printf("Error making query:%s!\n",mysql_error(con));

}

else{

printf("%s executed!\n",tmp);

}

//将查询结果保存到res结构体中

res = mysql_store_result(con);

//遍历查询结果的行

while(row = mysql_fetch_row(res)){

for(t=0;t<mysql_num_fields(res);t++){

//打印查询行内容

printf("%s \n",row[t]);

}

printf("-----------\n");

count++;

}

printf("number of rows %d\n", count);

printf("mysql_free_result...\n");

//释放结果内存

mysql_free_result(res);

//关闭数据库连接

mysql_close(con);

system("pause");

return 0;

}

9、将编译程序和libmysql.dll放在一个目录,然后执行即可

测试通过,十分有效

windows下C++操作MySQL数据库的更多相关文章

  1. windows 命令行操作 Mysql 数据库

    1 前言 有接手一个新项目,项目中到了 Mysql 数据库 ,这里总结下 windows 命令行操作 Mysql 数据库. 2 Cmd操作数据库 2.1 连接Mysql服务器,命令如下:(root用户 ...

  2. python【第十二篇下】操作MySQL数据库以及ORM之 sqlalchemy

    内容一览: 1.Python操作MySQL数据库 2.ORM sqlalchemy学习 1.Python操作MySQL数据库 2. ORM sqlachemy 2.1 ORM简介 对象关系映射(英语: ...

  3. Windows 下Java 连 MYSQL数据库

    我们上课的时候在机房是用java连SQLServer2008的.由于这个数据库软件安装太麻烦,最重要的一点是安装后系统应该会变慢.至少开机速度会有影响.至于这个mysql我觉得下载一个绿色版的,然后自 ...

  4. Windows下Qt连接MySql数据库

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

  5. Windows 下Python操作MySQL

    1.环境要求(Win7 X64): python 2.7, MySQL-python-1.2.3.win-amd64-py2.7 :http://www.codegood.com/download/1 ...

  6. windows下python操作mysql模块安装

    百度教程说安装 pip install mysqldb 这在我的电脑上安装失败: Could not find a version that satisfies the requirement mys ...

  7. ubuntu下C操作Mysql数据库第一步

    学习于: http://armsword.com/2013/06/20/ubuntu-c-mysql.html

  8. python操作三大主流数据库(1)python操作mysql①windows环境中安装python操作mysql数据库的MySQLdb模块mysql-client

    windows安装python操作mysql数据库的MySQLdb模块mysql-client 正常情况下应该是cmd下直接运行 pip install mysql-client 命令即可,试了很多台 ...

  9. Windows下安装MySQLdb, Python操作MySQL数据库的增删改查

    这里的前提是windows上已经安装了MySQL数据库,且配置完成,能正常建表能操作. 在此基础上仅仅需安装MySQL-python-1.2.4b4.win32-py2.7.exe就ok了.仅仅有1M ...

随机推荐

  1. 【pc杂谈】win7系统通过虚拟网卡共享wifi

    用管理员权限进入dos命令行 启用并设定虚拟WiFi网卡:netsh wlan set hostednetwork mode=allow  ssid=paulnet key=paulwinflo(注意 ...

  2. java对图片的处理

    原文地址:http://www.blogjava.net/PrettyBoyCyb/archive/2006/11/13/80922.html java 中的图片处理是很让人头疼的一件事情.目前 ja ...

  3. WinCE全屏手写输入法

    来源地址:http://www.dwhand.com/?page_id=570 WinCE全屏手写输入法 功能特点: 1.支持手写识别,智能拼音.仓颉.注音.笔画.五笔.ABC等输入模式. 2.支持各 ...

  4. yii2 memcache 跨平台交互 键和值不一样

    1 首先在配置文件中加载 web\basic\config\web.php ........ 'components' => [ 'request' => [ // !!! insert ...

  5. TCP heart

    http://blog.csdn.net/lisonglisonglisong/article/details/51327695

  6. 转转转![Spring MVC] - 500/404错误处理-SimpleMappingExceptionResolver

    参考博客: http://www.cnblogs.com/dongying/p/6129937.html http://www.cnblogs.com/rollenholt/archive/2012/ ...

  7. Java之MD5加密

    一.Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护.该算法的文件号为RFC 1321(R.Riv ...

  8. pythonNetday06

    进程 Process(target,name,args,kwargs) p.pid : 创建的新的进程的PID号 p.is_alive() 判断进程是否处于alive状态 p.daemon = Tru ...

  9. 【POJ】1062 昂贵的聘礼 (最短路)

    题目 传送门:QWQ 分析 最短路显然,但不好搞地位等级..... 地位等级不好搞?那么就暴力.. 枚举我们允许的地位等级,跑最短路. 所以$ n^2logn $出100什么鬼啊,很有迷惑性啊 还有4 ...

  10. 【UVA】11825 Hackers' Crackdown(状压dp)

    题目 传送门:QWQ 分析 $ n<= 16 $ 显然是状压 然后搞一搞(靠着蓝书yy一下) 代码 #include <bits/stdc++.h> using namespace ...