共计 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 小编将为大家输出更多高质量的实用文章!