当前位置: 首页 > news >正文

如何使用MySQL的API连接MySQL数据库?

本篇文章主要跟大家分享的是如何使用MySQL的API连接MySQL数据库,相信大家在日常生活中都有遇到过这种问题,因此,摩杜云小杜整理了一下并分享给大家做个参考,感兴趣的朋友记得要看完。下面,就跟着摩杜云小杜一起来看看吧!

C++连接MySQL数据库有两种方式:

1、通过MySQL 的C API(决定使用这种方式)

也可以使用MySQL++ 。

[Mysql++是官方发布的、一个为MySQL设计的C++语言的API。Mysql++为Mysql的C-Api的再次封装,它用STL(Standard Template Language)开发并编写,并为C++开发者提供像操作STL容器一样方便的操作数据库的一套机制]

2、通过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规范。

学习内容:如何使用MySql的API连接MySql数据库

一、工程设置

将工程的头文件路径指向Mysql安装目录的同文件mysql.h所在的位置,将连接库路径指向libmysql.lib所在的路径:
在这里插入图片描述
在这里插入图片描述


具体配置步骤:

1、项目属性页的C/C+±>常规->附加包含目录指向:C:Program FilesMySQLMySQL Server 5.1include

2、项目属性页的链接器->常规->附加库目录指向:C:Program FilesMySQLMySQL Server 5.1libopt.

3、将链接器->输入->附加依赖项中添加libmysql.lib(也可以在程序代码的开始处加上#pragma comment(lib,”D:Program FilesMySQLMySQL Server 5.6liblibmysql.lib”) 来导入libmysql.lib)

4、将D:Program FilesMySQLMySQL Server 5.6lib下的libmysql.dll拷到项目的debug文件夹,即跟输出文件一个文件夹下

二、连接Mysql和从MySql中取出数据的API

简单的连接数据库,获取数据库信息:

#include < windows.h>
#include < mysql.h>
#include < string>
#include < iostream>
using namespace std;

int main()
{

    const char user[] = "root";
    const char pswd[] = "root";
    const char host[] = "localhost";
    const char table[] = "bookdb";//数据库名
    unsigned int port = 3306;
    MYSQL myCont;
    MYSQL_RES *result;
    MYSQL_ROW sql_row;
    int res;
    mysql_init(&myCont);
    if (mysql_real_connect(&myCont, host, user, pswd, table, port, NULL, 0))
    {
        mysql_query(&myCont, "SET NAMES GBK"); //设置编码格式
        res = mysql_query(&myCont, "select * from bookInfo");//查询
        if (!res)
        {
            result = mysql_store_result(&myCont);
            if (result)
            {
                while (sql_row = mysql_fetch_row(result))//获取具体的数据
                {
                    cout << "BOOKNAME:" << sql_row[1] << endl;
                    cout << "    PRICE:" << sql_row[2] << endl;
                }
            }
        }
        else
        {
            cout << "query sql failed!" << endl;
        }
    }
    else
    {
        cout << "connect failed!" << endl;
    }
    if (result != NULL)
        mysql_free_result(result);
    mysql_close(&myCont);
    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的API连接MySQL数据库”的内容就到此介绍完毕,相信大家看完之后有一定的收获,如果还想了解更多相关知识,可以关注摩杜云行业资讯频道,更多精彩内容等着你来看。如果觉得这篇文章不错的话,也可以分享给更多的人看到。

相关文章:

  • 如何在Linux下彻底卸载MySQL?
  • 买一台服务器到底能干什么?可用于这7点!
  • 摩杜云将继续深耕云计算领域,赋能数字经济高质量发展
  • 哪些应用场景能使用摩杜云对象存储MOS?
  • 摩杜云2021上半年财报:营业总收入4亿元,同比增长2%
  • 为什么越来越多的网站安装了SSL证书?
  • 如何使用MySQL数据库来分析Apache日志?
  • 摩杜云:“国资云”杀入云计算行业,云计算行业的冬天要来了吗?
  • SSL证书过期怎么办?只需几步就能轻松解决!
  • 目前可以用的短信验证码平台有哪些?
  • SSL证书不受信任怎么办?重点关注这4点
  • 怎么发送电子邮件营销?关键在于这4点!
  • 新手必看!最简单的MySQL数据库详解
  • 国内哪家CDN加速服务好用?
  • 如何在MySQL 5.7中使用SELECT ... INTO语句导出数据文件?
  • #Java异常处理
  • (三)从jvm层面了解线程的启动和停止
  • [译] 怎样写一个基础的编译器
  • ABAP的include关键字,Java的import, C的include和C4C ABSL 的import比较
  • ES6系统学习----从Apollo Client看解构赋值
  • HTTP请求重发
  • Mysql优化
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • springboot_database项目介绍
  • vue 配置sass、scss全局变量
  • -- 查询加强-- 使用如何where子句进行筛选,% _ like的使用
  • 后端_MYSQL
  • 记一次和乔布斯合作最难忘的经历
  • 聊聊flink的BlobWriter
  • 你不可错过的前端面试题(一)
  • 前端相关框架总和
  • 设计模式(12)迭代器模式(讲解+应用)
  • 深度学习入门:10门免费线上课程推荐
  • 思考 CSS 架构
  • 微信小程序设置上一页数据
  • kubernetes资源对象--ingress
  • 完善智慧办公建设,小熊U租获京东数千万元A+轮融资 ...
  • ​io --- 处理流的核心工具​
  • ​LeetCode解法汇总2696. 删除子串后的字符串最小长度
  • ​你们这样子,耽误我的工作进度怎么办?
  • ​批处理文件中的errorlevel用法
  • ​软考-高级-系统架构设计师教程(清华第2版)【第20章 系统架构设计师论文写作要点(P717~728)-思维导图】​
  • !!java web学习笔记(一到五)
  • #我与Java虚拟机的故事#连载01:人在JVM,身不由己
  • #周末课堂# 【Linux + JVM + Mysql高级性能优化班】(火热报名中~~~)
  • $emit传递多个参数_PPC和MIPS指令集下二进制代码中函数参数个数的识别方法
  • (10)工业界推荐系统-小红书推荐场景及内部实践【排序模型的特征】
  • (2009.11版)《网络管理员考试 考前冲刺预测卷及考点解析》复习重点
  • (LeetCode C++)盛最多水的容器
  • (二)正点原子I.MX6ULL u-boot移植
  • (经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
  • (考研湖科大教书匠计算机网络)第一章概述-第五节1:计算机网络体系结构之分层思想和举例
  • (五)c52学习之旅-静态数码管
  • (转载)CentOS查看系统信息|CentOS查看命令
  • .NET 4.0中的泛型协变和反变