博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
通过MySQL C API界面(mysql自己提供的API方式访问mysql数据库)
阅读量:4128 次
发布时间:2019-05-25

本文共 4339 字,大约阅读时间需要 14 分钟。

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

2009-03-13 13:04:16|  分类: |字号 

通过VC开发MySQL数据库应用软件有多种方式:

一、通过MyODBC界面

二、通过Connector/C++l界面

三、通过MySQL C API界面

四、第三方封装的MySQL类

在经过反复比较,我还是选择了MySQL C API方式来进行MySQL的开发。

在VC中使用MySQL的步骤如下:

1、下载MySQL的服务器/客户端安装包

官方下载地址如下:

由于我的开发环境是Windows,所以我下载的是MySQL for Windows V4.0.12

2、安装MySQL服务器/客户端包

一般情况,选择下一步就行了。

默认情况,MySQL会安装到C:\mysql下。

3、在VC中设置其开发环境

[选项/项目/VC目录]

a.设置包含路径为c:\mysql\include

b.设置引用路径为c:\mysql\include

c.设置库路径为c:\mysql\lib\debug

[项目属性]

d.在设置链接器-输入-附加依赖项为libmySQL.lib

e.在stdafx.h中加入以下行:

#include <winsock.h>

#include "mysql.h"

4、至此就可以使用C API函数进行开发了。

FAQ:

1.若出现无法使用mysql.h定义的类型的错误时,可重新生成工程即可.

2.若出现链接错误,可将libmySQL.dll文件拷贝到工程当前目录下.

MySQL提供了很多函数来对数据库进行操作,大致可以分为以下几类:

第一部分 控制类函数

mysql_init()初始化MySQL对象

mysql_options()设置连接选项

mysql_real_connect()连接到MySQL数据库

mysql_real_escape_string()将查询串合法化

mysql_query()发出一个以空字符结束的查询串

mysql_real_query()发出一个查询串

mysql_store_result()一次性传送结果

mysql_use_result()逐行传送结果

mysql_free_result()释放结果集

mysql_change_user()改变用户

mysql_select_db()改变默认数据库

mysql_debug()送出调试信息

mysql_dump_debug_info()转储调试信息

mysql_ping()测试数据库是否处于活动状态

mysql_shutdown()请求数据库SHUTDOWN

mysql_close()关闭数据库连接

第二部分 信息获取类函数

mysql_character_set_name()获取默认字符集

mysql_get_client_info()获取客户端信息

mysql_host_info()获取主机信息

mysql_get_proto_info()获取协议信息

mysql_get_server_info()获取服务器信息

mysql_info()获取部分查询语句的附加信息

mysql_stat()获取数据库状态

mysql_list_dbs()获取数据库列表

mysql_list_tables()获取数据表列表

mysql_list_fields()获取字段列表

第三部分 行列类操作函数

mysql_field_count()获取字段数

mysql_affected_rows()获取受影响的行数

mysql_insert_id()获取AUTO_INCREMENT列的ID值

mysql_num_fields()获取结果集中的字段数

mysql_field_tell()获取当前字段位置

mysql_field_seek()定位字段

mysql_fetch_field()获取当前字段

mysql_fetch_field_direct()获取指定字段

mysql_frtch_fields()获取所有字段的数组

mysql_num_rows()获取行数

mysql_fetch_lengths()获取行长度

mysql_row_tell()获取当前行位置

mysql_row_seek()行定位

mysql_data_seek()行定位

mysql_fetch_row()获取当前行

第四部分 线程类操作函数

mysql_list_processes()返回所有线程列表

mysql_thread_id()获取当前线程ID

mysql_thread_safe()是否支持线程方式

mysql_kill()杀列一个线程

第五部分 出错处理类函数

mysql_errno()获取错误号

mysql_error()获取错误信息

第六部分 已过时的函数

mysql_connect()

mysql_create_db()

mysql_drop_db()

mysql_eof()

mysql_reload()

mysql_escape_string()

转载地址:http://qruvi.baihongyu.com/

你可能感兴趣的文章
百度产品经理群面
查看>>
去哪儿一面+平安科技二面+hr面+贝贝一面+二面产品面经
查看>>
element ui 弹窗在IE11中关闭时闪现问题修复
查看>>
vue 遍历对象并动态绑定在下拉列表中
查看>>
Vue动态生成el-checkbox点击无法选中的解决方法
查看>>
python __future__
查看>>
MySQL Tricks1
查看>>
python 变量作用域问题(经典坑)
查看>>
pytorch
查看>>
pytorch(三)
查看>>
ubuntu相关
查看>>
C++ 调用json
查看>>
nano中设置脚本开机自启动
查看>>
动态库调动态库
查看>>
Kubernetes集群搭建之CNI-Flanneld部署篇
查看>>
k8s web终端连接工具
查看>>
手绘VS码绘(一):静态图绘制(码绘使用P5.js)
查看>>
手绘VS码绘(二):动态图绘制(码绘使用Processing)
查看>>
基于P5.js的“绘画系统”
查看>>
《达芬奇的人生密码》观后感
查看>>