如何使用MySql的API连接MySql数据库

59次阅读
没有评论

共计 3892 个字符,预计需要花费 10 分钟才能阅读完成。

本篇内容介绍了“如何使用 MySql 的 API 连接 MySql 数据库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让丸趣 TV 小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

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 所在的路径:

br 具体配置步骤:
1、项目属性页的 C /C++- 常规 - 附加包含目录指向:C:\Program Files\MySQL\MySQL Server 5.1\include
2、项目属性页的链接器 - 常规 - 附加库目录指向:C:\Program Files\MySQL\MySQL Server 5.1\lib\opt.
3、将链接器 - 输入 - 附加依赖项中添加 libmysql.lib(也可以在程序代码的开始处加上 #pragma comment(lib, D:\Program Files\MySQL\MySQL Server 5.6\lib\libmysql.lib) 来导入 libmysql.lib)
4、将 D:\Program Files\MySQL\MySQL Server 5.6\lib 下的 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 数据库”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注丸趣 TV 网站,丸趣 TV 小编将为大家输出更多高质量的实用文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-01发表,共计3892字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)