返回顶部
首页 > 资讯 > 数据库 >C++操作MySQL的实现示例
  • 941
分享到

C++操作MySQL的实现示例

C++操作MySQLC++MySQL 2022-05-20 00:05:06 941人浏览 泡泡鱼
摘要

Windows版本:       将libMysql.dll、libmysql.lib、mysql.h复制粘贴到项目文件中,或者项目设置里的包含目录和库目录添加路径

Windows版本:

      将libMysql.dll、libmysql.lib、mysql.h复制粘贴到项目文件中,或者项目设置里的包含目录和库目录添加路径


#include <iOStream>
#include<iomanip>
#include "winsock.h" 
#include "mysql.h" 
#pragma comment(lib,"libmySQL.lib")

using namespace std;

int main()
{
 MYSQL* m_sqlCon;
 MYSQL_RES* res_set;
 MYSQL_ROW row;
 MYSQL_FIELD* field;

 m_sqlCon = mysql_init((MYSQL*)0);
 if (!mysql_real_connect(m_sqlCon, "localhost", "root", "123456", "test", 3306, NULL, 0))
 {
  cerr << "Failed to connect to database: Error: " << mysql_error(m_sqlCon) << endl;
 }
 else
 {
  cerr << "Successfully connected to Database." << endl;
  cout << endl;

  string pQuery = "select * from my_table";
  int status = mysql_real_query(m_sqlCon, pQuery.c_str(), (UINT)strlen(pQuery.c_str()));  //输入命令

  res_set = mysql_store_result(m_sqlCon);

  field = mysql_fetch_fields(res_set); //获取所有列名
  int field_count = mysql_field_count(m_sqlCon);  //获取列数

             
  for (int i = 0; i < field_count; i++) //输出所有列名
  {
   cout << setw(15) << field[i].name; //总共占15格
  }
  cout << endl;

  int row_count = mysql_num_rows(res_set); //获取行数

  while (row = mysql_fetch_row(res_set))  //输出所有行数据
  {
   for (int i = 0; i < field_count; i++)
   {
    cout << setw(15) << row[i];
   }
   cout << endl;
  }
 }

 mysql_close(m_sqlCon);

 system("pause");
 return 0;
}

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() 初始化一个一行一行地结果集合的检索。

通过MySQL的Connector C++

MySQL c++ Driver的实现基于JDBC规范

MySQL Connector/C++是由Sun Microsystems开发的MySQL连接器。它提供了基于OO的编程接口与数据库驱动来操作MySQL服务器。

与许多其他现存的C++接口实现不同,Connector/C++遵循了JDBC规范。也就是说,Connector/C++ Driver的API主要是基于Java语言的JDBC接口。JDBC是java语言与各种数据库连接的标准工业接口。

Connector/C++实现了大部分JDBC规范。如果C++程序的开发者很熟悉JDBC编程,将很快的入门

MySQL Connector/C++需要安装配置boost库,boost库安装编译在这里不进行阐述

新建一个空项目,

将F:\MySQL\Connector C++ 1.1.3\lib\opt添加到项目的库目录中(根据具体路径而定)

将F:\MySQL\Connector C++ 1.1.3\include添加到VC++的包含目录中(根据具体路径而定),

将F:\boost\boost_1_55_0添加到VC++的包含目录中(根据具体路径而定)

添加mysqlcppconn.lib至链接器--->输入--->附加依赖项中

同样,如果使用的mysql是64位的,还需要将项目的解决方案平台由win32改成x64

将F:\MySQL\Connector C++ 1.1.3\lib\opt(根据具体路径而定)下的mysqlcppconn.dll复制到项目中去,和.cpp,.h文件位于同一路径下
将F:\MySQL\MySQL Server 5.6\lib(根据具体路径而定)下的libmysql.dll复制到项目中去,和.cpp,.h文件位于同一路径下(配置完成)


#include <iostream>
#include <map>
#include <string>
#include <memory>
#include "mysql_driver.h"
#include "mysql_connection.h"
#include "cppconn/driver.h"
#include "cppconn/statement.h"
#include "cppconn/prepared_statement.h"
#include "cppconn/metadata.h"
#include "cppconn/exception.h"
 
using namespace std;
using namespace sql;
 
int main()
{
  sql::mysql::MySQL_Driver *driver = 0;
  sql::Connection *conn = 0;
 
  try
  {
    driver = sql::mysql::get_mysql_driver_instance();
    conn = driver->connect("tcp://localhost:3306/booktik", "root", "123456");
    cout << "连接成功" << endl;
  }
  catch (...)
  {
    cout << "连接失败" << endl;
  }
  sql::Statement* stat = conn->createStatement();
  stat->execute("set names 'gbk'");
  ResultSet *res;
  res = stat->executeQuery("SELECT * FROM BOOK");
  while (res->next())
  {
    cout << "BOOKNAME:" << res->getString("bookname") << endl;
    cout << "  SIZE:" << res->getString("size") << endl;
  }
  if (conn != 0)
  {
    delete conn;
  }
}

Linux版本:


#include <iostream>
#include <string>
#include "/usr/include/mysql/mysql.h"

using namespace std;

class MyDb 
{
public:
 MyDb();
 ~MyDb();
 bool initDB(string host, string user,string pwd,string db_name, int port);
 bool exeSQL(string sql);

private:
 MYSQL *mysql;
 MYSQL_RES *result;
 MYSQL_ROW row;
};

MyDb::MyDb()
{
 mysql = mysql_init(NULL);

 if(!mysql) {
  cout<<"Error:"<<mysql_error(mysql);
  exit(1);
 }
}

MyDb::~MyDb()
{
 if(mysql) {
  mysql_close(mysql);
 }
}

bool MyDb::initDB(string host, string user, string passwd, string db_name, int port = 3306)
{
 mysql = mysql_real_connect(mysql, host.c_str(),
    user.c_str(), passwd.c_str(), db_name.c_str(), port, NULL, 0);
 if(!mysql) {
  cout << "Error: " << mysql_error(mysql);
  exit(1);
 }

 return true;
}

bool MyDb::exeSQL(string sql)
{
 //mysql_query()执行成功返回0,执行失败返回非0值。
 if (mysql_query(mysql,sql.c_str())) {
  cout<<"Query Error: "<<mysql_error(mysql);
  return false;
 }

 result = mysql_store_result(mysql);

 if (result) {
  //获取结果集中总共的字段数,即列数
  int num_fields = mysql_num_fields(result);
  unsigned long long num_rows = mysql_num_rows(result);

  for(unsigned long long i = 0; i < num_rows; i++) {
   row = mysql_fetch_row(result);
   if(!row) {
    break;
   }

   for(int j=0;j<num_fields;j++) {
    cout<<row[j]<<"\t\t";
   }
   cout<<endl;
  }
 } else {
  //代表执行的是update,insert,delete类的非查询语句
  if (mysql_field_count(mysql) == 0) {
   // 返回update,insert,delete影响的行数
   unsigned long long num_rows = mysql_affected_rows(mysql);

   return num_rows;
  } else {
   cout << "Get result error: " << mysql_error(mysql);
   return false;
  }
 }

 return true;
}

int main() 
{
 MyDb db;

 string host = "127.0.0.1";
 string user = "skynet";
 string passwd = "123456";
 string dbName = "skynet";
 int port = 3306;

 //连接数据库
 bool conn = db.initDB(host, user, passwd, dbName, port);

 if (!conn) {
  cout<<"connect fails\n";
 }

 cout<<"ok" <<endl;

 //将所有用户信息读出,并输出。
 string sql = "SELECT * from test;";
 db.exeSQL(sql);

 return 0;
}

到此这篇关于C++操作MySQL的实现示例的文章就介绍到这了,更多相关C++操作MySQL内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

您可能感兴趣的文档:

--结束END--

本文标题: C++操作MySQL的实现示例

本文链接: https://lsjlt.com/news/9533.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C++操作MySQL的实现示例
    Windows版本:       将libmysql.dll、libmysql.lib、mysql.h复制粘贴到项目文件中,或者项目设置里的包含目录和库目录添加路径...
    99+
    2022-05-20
    C++操作MySQL C++ MySQL
  • Go操作etcd的实现示例
    目录etcdetcd介绍etcd应用场景服务发现配置中心分布式锁为什么用 etcd 而不用ZooKeeper?为什么不选择ZooKeeper?为什么选择etcd?etcd集群搭建一个...
    99+
    2024-04-02
  • Golang操作Kafka的实现示例
    目录一.使用库说明二.Kafka Producer发送消息三.Kafka Consumer消费消息一.使用库说明 Golang中连接kafka可以使用第三方库:github.com/...
    99+
    2023-02-19
    Golang操作Kafka Golang Kafka
  • C#调用FFmpeg操作音视频的实现示例
    目录项目背景FFmpeg介绍FFmpeg相关教程博客示例源码下载FFmpeg.exe安装包C#进程调用FFmpeg操作音视频项目背景   因为公司需要对音视频做一些操作,比如说对系统...
    99+
    2024-04-02
  • MySQL实现数据插入操作的示例详解
    目录一、方法分类二、具体方法三、实例(1)常规插入(2)从另一个表导入(3)插入时数据重复四、注意事项(1)不写字段名,需要填充自增ID(2)按字段名填充,可以不录入id其余注意事项使用mysql插入数据时,可以根据需求...
    99+
    2023-02-21
    MySQL数据插入操作 MySQL数据插入 MySQL数据
  • C#操作Excel实现的实例分析
    C#操作Excel实现的实例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。C#操作Excel是怎么样执行的呢?我们在实际的C#操作Excel开发程序过程中主要会使用到那些方...
    99+
    2023-06-17
  • C语言实现堆的简单操作的示例代码
    目录一、堆的概念二、堆的实现三、堆的代码实现一、堆的概念 (1)定义 如果有一个关键码的集合K = {k0,k1, k2,…,kn-1},把它的所有元素按完全二叉树的顺...
    99+
    2022-11-13
    C语言实现堆 C语言 堆操作 C语言
  • gearman + mysql方式实现持久化操作示例
    本文实例讲述了gearman+mysql方式实现持久化操作。分享给大家供大家参考,具体如下: 为什么要持久化? gearman的job server中的工作队列存储在内存中,一旦服务器有未处理的任务时重启或者...
    99+
    2022-05-18
    gearman mysql 持久化
  • C++操作符的示例分析
    这篇文章给大家介绍C++操作符的示例分析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。C++操作符是C++中的一个高级C++技术,下面进行相关介绍,或许你发现,有些操作符使用了相同的符号,符号的意义可以随环境进行改变,...
    99+
    2023-06-17
  • go语言操作es的实现示例
    目录Elasticsearch介绍Elasticsearch能做什么go语言操作es解决golang使用elastic连接elasticsearch时自动转换连接地址初始化数据创建查...
    99+
    2024-04-02
  • python操作mysql、excel、pdf的示例
    目录一、学习如何定义一个对象 二、学习如何连接MySQL并查询 三、学习如何读写csv 四、读取xlsx 五、读写PDF 一、学习如何定义一个对象 代码: #!/usr/bin...
    99+
    2024-04-02
  • C语言实现对文件进行操作的示例详解
    目录前言文件指针文件的打开和关闭文件的打开方式文件读写函数二进制方式存储文件对文件进行拷贝文件随机读写函数文件缓冲区前言 文件操作 在运行程序的时候,此时数据是存放在内存中,当程序退...
    99+
    2023-05-15
    C语言实现文件操作 C语言文件操作 C语言文件
  • C语言实现顺序表的基本操作的示例详解
    目录一、认识顺序表1.线性表2.顺序表的概念及结构二、顺序表的基本操作(接口实现)1.初始化顺序表2.打印顺序表3.尾插4.尾删5.扩容6.头插7.头删8.任意位置插入9.任意位置删...
    99+
    2022-11-13
    C语言顺序表基本操作 C语言顺序表操作 C语言顺序表
  • java操作gaussDB数据库的实现示例
    本文主要介绍了java操作gaussDB数据库的实现示例,分享给大家,具体如下: package com.shiwusuo.ReadHdfsToClickHouse.gauss i...
    99+
    2024-04-02
  • golang操作连接数据库实现mysql事务示例
    目录mysql驱动posgre驱动连接postgres连接mysql初始化连接SetMaxOpenConnsSetMaxIdleConnsCRUD查询单行查询QueryRow多行查询...
    99+
    2024-04-02
  • python操作Mysql实例
    本文介绍了Python操作mysql,执行SQL语句,获取结果集,遍历结果集,取得某个字段,获取表字段名,将图片插入数据库,执行事务等各种代码实例和详细介绍。 实例1、获取MYSQL的版本 #!/usr/bin/env python   i...
    99+
    2023-01-31
    实例 操作 python
  • MySQL中行记录的操作示例
    这篇文章主要介绍MySQL中行记录的操作示例,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在Mysql管理软件中, 可以通过sql语句中的dml语言来实现数据的操作, 包括1、使用I...
    99+
    2024-04-02
  • Mysql中join操作的示例分析
    小编给大家分享一下Mysql中join操作的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!join的类型1.  ...
    99+
    2024-04-02
  • mysql权限操作的示例分析
    这篇文章给大家分享的是有关mysql权限操作的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 1、创建新用户: create user mark@localhost ...
    99+
    2024-04-02
  • C语言操作符的示例分析
    这篇文章给大家分享的是有关C语言操作符的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言C语言中操作符不多,但是有些相同的操作符都是在不同的表达式中,有不同的解释意思,比如 * 号,在表达式中5*5表示...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作