C++连接mysql有2种方法:利用ADO连接、利用mysql自己的api函数进行连接,下面看看如何用吧。

第一种方法可以实现我当前的需求,通过连接不同的字符串来连接不同的数据库。暂时只连接了mysql,sqlserver,oracle,access。

对于access,因为它创建表的SQL语句不太兼容标准SQL语句,需要做一些处理,这里暂时不说。

第二种方法只能针对于mysql数据库的连接,不过用这种方法不用安装MyODBC服务器程序。

不管用哪种方法,首先需要安装Mysql数据库,安装方法请看“mysql安装及一些注意点”。最好安装一个Navicat for mysql,

方便操作mysql数据库。下面分别说下这两种方法:

(一)通过ADO连接MySql数据库

1、通过ADO连接MySql数据库,首先得安装MyODBC服务器程序。

MyODBC版本要和MySql的版本对应上,否则会连接不上数据库。我用的版本分别是mysql-5.1.48-win32.msi和mysql-connector-odbc-5.1.5-win32.msi。

安装好后,点击开始菜单->设置->控制面板->管理工具->数据源(ODBC)->用户DSN->添加->选择MySQL ODBC 5.1 Driver。

然后双击MySQL ODBC 5.1 Driver进行配置。配置好可以点Test进行下测试,如果能连上会弹出connection successful对话框。

Data Source Name:中的内容就是代码里DSN所对应的值。

例如:"DSN=MySqlODBC;server=localhost;database=test"。

2、配置好后,就可以开始编码了。

(1)首先导入ADO类型库。#import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")。

您的环境中msado15.dll不一定在这个目录下,请按实际情况修改。或者把msado15.dll这个文件拷贝到你的工程目录下,直接#import "msado15.dll" \ no_namespace \rename ("EOF", "adoEOF")包含进来。

(2 )创建Connection对象并连接数据库

{

CoInitialize(NULL);

m_pConnection.CreateInstance(__uuidof(Connection));try{//设置连接时间

m_pConnection->ConnectionTimeout = 5;//打开数据库连接

HRESULT hr = m_pConnection->Open("DSN=MySqlODBC;server=localhost;database=test","root","root",adModeUnknown);

}catch(_com_error &e)

{

MessageBox(NULL, e.Description(), _T(""), MB_OK);returnFALSE;

}returnTRUE;

}

(3)执行SQL语句

BOOL CDBManagerSub::ExecuteSQL( _bstr_t bstrSQL )

{//_variant_t RecordsAffected;

try{//是否已经连接数据库

if(m_pConnection ==NULL)

{//重新连接数据库

Open(m_dbType, m_strServer, m_strUserName, m_strPasswor, m_strDBName);

}//Connection对象的Execute方法:(_bstr_t CommandText,//VARIANT * RecordsAffected, long Options )//其中CommandText是命令字串,通常是SQL命令。//参数RecordsAffected是操作完成后所影响的行数,//参数Options表示CommandText的类型:adCmdText-文本命令;adCmdTable-表名//adCmdProc-存储过程;adCmdUnknown-未知

_RecordsetPtr hr = m_pConnection->Execute(bstrSQL,NULL,adCmdText);return true;

}catch(_com_error e)

{

MessageBox(NULL, e.Description(), _T(""), MB_OK);return false;

}

}

_bstr_t bstrSQL为输入的SQL语句,如果返回TRUE,则执行成功,返回FLASH则会报对应的错误提示。

例如:下面的创建testTable表的SQL语句:

char* pQuery = "create table if not exists testTable( ID VARCHAR(10), Name VARCHAR(255),Descs VARCHA(255),PRIMARY KEY (ID))";

ExecuteSQL(pQuery);

3、附上mysql数据库的操作,方便没有安装Navicat for mysql的朋友参考。

打开“开始->所有程序->MySQL->MySQL Server 5.0->MySQL Command Line Client.exe”,如果没有设置密码就直接按回车,会提示服务器启动成功。

mysql> SHOW DATABASES;//显示所有的数据库,注意一定要 敲“;”后再按回车

mysql> CREATE DATABASE mydb;//创建数据库

mydbmysql> USE mydb;//选择你所创建的数据库

mydbmysql> SHOW TABLES; //显示数据库中的表

mysql> CREATE TABLE mytable (username VARCHAR(100), visitelist VARCHAR(200),remark VARCHAR(200),PRIMARY KEY (username));//创建一个表mytable: 用户名;访问列表,主键为username

mysql> DESCRIBE mytable;//显示表的结构

(二)通过MySQL自己的API函数进行连接

1、使用API的方式连接,需要加载mysql的头文件和lib文件。

在VS2010的附加包含目录中添加\MySQL\MySQL Server 5.1\include。在安装MySql的目录下找。 把libmysql.dll和libmysql.lib文件拷贝到所建的工程目录下。然后在头文件里包含以下内容:

//mysql所需的头文件和库文件

#include "winsock.h"#include"mysql.h"

#pragma comment(lib,"libmySQL.lib")

2、进行编码

(1)连接mysql数据库

头文件里定义数据源指针 MYSQL m_sqlCon;

//连接MySql数据库

try{

mysql_init(&m_sqlCon);//localhost:服务器 root为账号密码 test为数据库名 3306为端口

if(!mysql_real_connect(&m_sqlCon, "localhost","root","root","test",3306,NULL,0))

{

AfxMessageBox(_T("数据库连接失败!"));returnFALSE;

}returnTRUE;

}catch(...)

{returnFALSE;

}

(2)关闭数据库

mysql_close(&m_sqlCon);

(3)创建表

char* pQuery = "create table if not exists DS_Building( ID VARCHAR(10),Name VARCHAR(255),Descs VARCHAR(255),PRIMARY KEY (ID))";

if(mysql_real_query(&m_sqlCon,pQuery,(UINT)strlen(pQuery))!=0)

{const char* pCh = mysql_error(&m_sqlCon);returnFALSE;

}

附MySQL的API接口:

mysql_affected_rows() 返回被最新的UPDATE, DELETE或INSERT查询影响的行数。

mysql_close() 关闭一个服务器连接。

mysql_connect() 连接一个MySQL服务器。该函数不推荐;使用mysql_real_connect()代替。

mysql_change_user() 改变在一个打开的连接上的用户和数据库。

mysql_create_db() 创建一个数据库。该函数不推荐;而使用SQL命令CREATE DATABASE。

mysql_data_seek() 在一个查询结果集合中搜寻一任意行。

mysql_debug() 用给定字符串做一个DBUG_PUSH。

mysql_drop_db() 抛弃一个数据库。该函数不推荐;而使用SQL命令DROP DATABASE。

mysql_dump_debug_info() 让服务器将调试信息写入日志文件。

mysql_eof() 确定是否已经读到一个结果集合的最后一行。这功能被反对; mysql_errno()或mysql_error()可以相反被使用。

mysql_errno() 返回最近被调用的MySQL函数的出错编号。

mysql_error() 返回最近被调用的MySQL函数的出错消息。

mysql_escape_string() 用在SQL语句中的字符串的转义特殊字符。

mysql_fetch_field() 返回下一个表字段的类型。

mysql_fetch_field_direct () 返回一个表字段的类型,给出一个字段编号。

mysql_fetch_fields() 返回一个所有字段结构的数组。

mysql_fetch_lengths() 返回当前行中所有列的长度。

mysql_fetch_row() 从结果集合中取得下一行。

mysql_field_seek() 把列光标放在一个指定的列上。

mysql_field_count() 返回最近查询的结果列的数量。

mysql_field_tell() 返回用于最后一个mysql_fetch_field()的字段光标的位置。

mysql_free_result() 释放一个结果集合使用的内存。

mysql_get_client_info() 返回客户版本信息。

mysql_get_host_info() 返回一个描述连接的字符串。

mysql_get_proto_info() 返回连接使用的协议版本。

mysql_get_server_info() 返回服务器版本号。

mysql_info() 返回关于最近执行得查询的信息。

mysql_init() 获得或初始化一个MYSQL结构。

mysql_insert_id() 返回有前一个查询为一个AUTO_INCREMENT列生成的ID。

mysql_kill() 杀死一个给定的线程。

mysql_list_dbs() 返回匹配一个简单的正则表达式的数据库名。

mysql_list_fields() 返回匹配一个简单的正则表达式的列名。

mysql_list_processes() 返回当前服务器线程的一张表。

mysql_list_tables() 返回匹配一个简单的正则表达式的表名。

mysql_num_fields() 返回一个结果集合重的列的数量。

mysql_num_rows() 返回一个结果集合中的行的数量。

mysql_options() 设置对mysql_connect()的连接选项。

mysql_ping() 检查对服务器的连接是否正在工作,必要时重新连接。

mysql_query() 执行指定为一个空结尾的字符串的SQL查询。

mysql_real_connect() 连接一个MySQL服务器。

mysql_real_query() 执行指定为带计数的字符串的SQL查询。

mysql_reload() 告诉服务器重装授权表。

mysql_row_seek() 搜索在结果集合中的行,使用从mysql_row_tell()返回的值。

mysql_row_tell() 返回行光标位置。

mysql_select_db() 连接一个数据库。

mysql_shutdown() 关掉数据库服务器。

mysql_stat() 返回作为字符串的服务器状态。

mysql_store_result() 检索一个完整的结果集合给客户。

mysql_thread_id() 返回当前线程的ID。

mysql_use_result() 初始化一个一行一行地结果集合的检索。

通过本文的介绍,希望你对C++连接mysql数据库的两种方法有所了解

c++向mysql通信_C++连接MySQL相关推荐

  1. 引入mysql+命名空间_C#连接MySQL操作详细教程

    C#如何连接MySQL进行操作,供大家参考,具体内容如下 1.引入MySql.Data.dll 例如小编是vs2017,创建工程之后,添加应用,选择工程,点击下面的引用,右击打开,选择添加引用 2.如 ...

  2. c# 连接mysql数据库_C#连接Mysql数据库

    一. ADO.NET访问方式 程序集:Mysql.Data.dll 导入包:using MySql.Data.MySqlClient; 说明:这是MySql为 ADO.NET推出的 访问 Mysql数 ...

  3. c winform mysql类_C#连接MySQL数据库操作类

    首先需要安装MySQL Connector Net 6.8.3 然后在项目中引用MySQL Connector,如下图所示 C#连接MySQL的操作类代码如下:public class MySQLHe ...

  4. c 连接mysql数据库_C++连接mysql数据库的两种方法

    现在正做一个接口,通过不同的连接字符串操作不同的数据库.要用到mysql数据库,以前没用过这个数据库,用access和sql server比较多.通过网上的一些资料和自己的摸索,大致清楚了C++连接m ...

  5. cad与连接mySQL数据库_C++连接mysql数据库的两种方法

    现在正做一个接口,通过不同的连接字符串操作不同的数据库.要用到mysql数据库,以前没用过这个数据库,用access和sql server比较多.通过网上的一些资料和自己的摸索,大致清楚了C++连接m ...

  6. c# mysql 编码_c# 连接MySQL中文乱码问题的正确方案

    以下的文章主要向大家介绍的是c# 连接MySQL中文乱码问题的正确解决方法,一开始不太清楚为什么整个数据库的默认配置都为utf-8,而且有些人在使用http协议传送utf-8的汉字时,是正确的执行了的 ...

  7. c web mysql数据库_C连接Mysql数据库代码

    //vc工具中添加E:\WAMP\BIN\MYSQL\MYSQL5.5.8\LIB 路径 //在工程设置->链接>库模块中添加 libmysql.lib #include #include ...

  8. 使用php连接mysql数据库_PHP使用mysql与mysqli连接Mysql数据库用法示例

    本文实例讲述了PHP使用mysql与mysqli连接Mysql数据库的方法.分享给大家供大家参考,具体如下: 代码很简单直接上了 /** * @Author: HTL * @Description: ...

  9. django本地安装mysql_Ununtu 15.04 安装MySql(Django连接Mysql)

    本文介绍Ubuntu 15.04下安装MySQL ubuntu 15.04安装mysql django项目连接mysql 一.安装数据库 1.sudo apt-get install mysql-se ...

最新文章

  1. 设计模式学习(三)——装饰器模式
  2. 构建高性能WEB站点笔记二
  3. 在工作之余,你是怎么提升自己的?
  4. linux selenium_Selenium的基本使用方法
  5. SQL*Plus环境下创建PLUSTRACE角色
  6. 14.程序员常用10种算法
  7. 部署Exchange 2010
  8. redis中内存碎片处理
  9. 2021_IJCAI_Graph Learning based Recommender Systems: A Review—(IJCAI, 2021)
  10. jnlp文件服务器数据提取,jnlp 项目示例
  11. Java之HTTP网络编程(下篇:网页浏览器程序设计)
  12. f_sync解决fatfs文件掉电数据丢失问题
  13. 迷阵突围(dijkstra求次短路径)
  14. 简历类个人网站如何制作?
  15. 百度网盘配合插件脚本使用IDM下载设置
  16. 【Python爬虫】爬取2022软科全国大学排行榜
  17. OPDS书库目录总结(添加OPDS书库目录)
  18. 【教程】dropbox+droppages搭建静态网页
  19. 超简洁的群晖交叉编译教程
  20. 2018寒假编程总结1

热门文章

  1. java比c好逆向,吐槽一下java的效率。。。比起C差的真的好远。。。
  2. Mysql-索引的基础和类型
  3. 【经典回放】多种语言系列数据结构算法:堆排序
  4. Git之创建远程分支和删除远程分支
  5. Android之提示A failure occurred while executing org.jetbrains.kotlin.gradle.internal.KaptExecution
  6. Android之简单背景颜色渐变实现
  7. Android之切换账号登录依然能登录成功问题解决办法
  8. Android之在ubuntu上用aapt查看apk的名字以及相关信息
  9. Android之 如何解决ScrollView 和ListView滑动冲突的问题如何解决ScrollView can host only one direct child
  10. 【iVX 初级工程师培训教程 10篇文拿证】01 了解 iVX 完成新年贺卡