- 浏览: 13934 次
最新评论
vc++连接MySQL数据库、mysql api函数
2011年03月08日
本章介绍了MySQL可使用的API,从哪里获得它们,以及如何使用它们。 详细介绍C API,这是因为它是由MySQL团队开发的,而且它也是大多数其他API的基础。 本章还介绍了libmysqld库(嵌入式服务器),以及对应用程序开发人员有用的一些程序。 使用嵌入式MySQL服务器库,能够在客户端应用程序中使用具备全部特性的MySQL服务器。 主要优点在于,增加了速度,并使得嵌入式应用程序的管理更简单。
嵌入式服务器库是以MySQL的客户端/服务器版本为基础的,采用C/C++语言编写。 其结果是嵌入式服务器也是用C/C++语言编写的。 在其他语言中,嵌入式服务器不可用。
API与嵌入式MySQL版本和客户端/服务器版本等效。 要想更改旧的线程式应用程序以使用嵌入式库,正常情况下,仅需添加对下述函数的调用即可。 函数 何时调用 mysql_server_init() 应在调用任何其他MySQL函数之前调用,最好是在main()函数中调用。 mysql_server_end() 应在程序退出前调用。 mysql_thread_init() 应在你所创建的、用于访问MySQL的每个线程中调用。 mysql_thread_end() 应在调用pthread_exit()之前调用。 随后,必须将你的代码与libmysqld.a链接起来,而不是libmysqlclient.a。 在libmysqlclient.a中还包含mysql_server_xxx()函数,使用这类函数,通过将应用程序链接到恰当的库,即可在嵌入式版本和客户端/服务器版本之间切换。 请参见25.2.12.1节,"mysql_server_init()"。 嵌入式服务器和独立服务器之间的一项差别在于,对于嵌入式服务器,默认情况下,连接鉴定是禁止的。 对于嵌入式服务器,要想使用鉴定功能,可在激活"configure"以配置MySQL分发版时使用"--with-embedded-privilege-control"选项。 要想获得libmysqld库,应使用"--with-embedded-server"选项配置MySQL。 请参见2.8.2节,"典型配置选项"。
将你的程序与libmysqld链接时,还必须包含系统的pthread库以及MySQL服务器使用的一些库。 执行"mysql_config --libmysqld-libs",可获得库的完整列表。
对于线程程序的编译和链接,必须使用正确的标志,即使你未在代码中直接调用任何线程函数也同样。
要想编译C程序以包含必要文件,并将MySQL服务器库嵌入到程序的编译版本中,可使用GNU C编译器(gcc)。 编译器需要知道各种文件的位置,并需了解如何编译程序的指令。 在下面的示例中,介绍了如何从命令行编译程序的方法: 在gcc命令后紧跟着未编译C程序文件的名称。 接下来,给定的"-o"选项指明,它后面的文件名是编译器将输出文件的名称,即编译后的程序。 在下一行的代码中,通知编译器获取包含文件和库的位置,以及在其上进行编译的系统的其他设置。 由于"mysql_config"存在的问题,在此添加了"-lz"选项(压缩)。 "mysql_config"部分包含在backticks中,而不是单引号内。 嵌入式服务器存在下述限制:
. 不支持ISAM表。 (这样做的主要目的是为了使库更小)。
. 没有自定义函数(UDF)。
. 没有对核心转储的堆栈跟踪。
. 没有内部RAID支持。 (由于大多数当前操作系统均支持大文件,通常情况下不需要它)。
. 不能将其设置为"主"或"从"(无复制)。
. 在内存较低的系统上,可能无法使用很大的结果集。
. 不能使用套接字或TCP/IP从外部进程连接到嵌入式服务器。 但是,你可以连接到中间应用程序,随后,该中间应用程序可代表远程客户端或外部进程连接到嵌入式服务器。
通过编辑"mysql_embed.h"包含文件并重新编译MySQL,可更改某些限制。 对于任何能够与mysqld服务器端口监督程序一起给定的选项,也可以与嵌入式服务器库一起使用。在数组中,可将服务器选项作为参量指定给用于初始化服务器的mysql_server_init()。也能在诸如my.cnf的选项文件中给定它们。要想为C程序指定选项文件,请使用"--defaults-file"选项作为函数mysql_server_init()的第2个参量的元素之一。关于mysql_server_init()函数的更多信息,请参见 25.2.12.1节,"mysql_server_init()"。
使用选项文件,能够简化客户端/服务器应用程序和嵌入了MySQL的应用程序之间的切换。将常用选项置于[server]组。它们可被两种MySQL版本读取。客户端/服务器选项应被放在[mysqld]部分。将嵌入式MySQL服务器库的选项放在[embedded]部分。将与应用程序相关的选项放在标记为[ApplicationName_SERVER]的部分。请参见4.3.2节,"使用选项文件"。 . 我们将提供一些选项以省去MySQL的某些部分,从而使库变得更小。
. 仍有很多速度优化工作需要完成。
. 错误将被写入stderr。我们将增加1个选项为它们指定文件名。
. 使用嵌入式版本时,需要更改InnoDB,使之不再冗长。如果你的数据库不含InnoDB表,要想抑制相关消息,可为组[libmysqd_server]下的选项文件增加"--skip-innodb"选项,或在用mysql_server_init()初始化服务器时添加该选项。 在Linux或FreeBSD系统上,无需更改就能使用下面这两个示例程序。对于其他操作系统,需要进行小的修改,主要是文件路径。设计这两个示例的目的在于,为你提供足够的细节信息,以便理解问题,它们是实际应用程序的必要组成部份。第1个示例十分直观。第2个示例采用了一些错误检查功能,略为复杂。在第1个示例的后面,给出了用于编译程序的命令行条目。在第2个示例的后面,给出了GNUmake文件,该文件可用于编译。
示例:1
test1_libmysqld.c #include #include #include #include "mysql.h" MYSQL *mysql;MYSQL_RES *results;MYSQL_ROW record; static char *server_options[] = { "mysql_test", "--defaults-file=my.cnf" };int num_elements = sizeof(server_options)/ sizeof(char *); static char *server_groups[] = { "libmysqld_server", "libmysqld_client" }; int main(void){ mysql_server_init(num_elements, server_options, server_groups); mysql = mysql_init(NULL); mysql_options(mysql, MYSQL_READ_DEFAULT_GROUP, "libmysqld_client"); mysql_options(mysql, MYSQL_OPT_USE_EMBEDDED_CONNECTION, NULL); mysql_real_connect(mysql, NULL,NULL,NULL, "database1", 0,NULL,0); mysql_query(mysql, "SELECT column1, column2 FROM table1"); results = mysql_store_result(mysql); while((record = mysql_fetch_row(results))) { printf("%s - %s \n", record[0], record[1]); } mysql_free_result(results); mysql_close(mysql); mysql_server_end(); return 0;}
下面给出了编译上述程序的命令行命令: 示例:2
要想检验该示例,创建一个与MySQL源目录同级的test2_libmysqld目录。将test2_libmysqld.c源文件和GNUmakefile保存到该目录,并在test2_libmysqld目录下运行GNU make。
test2_libmysqld.c /* * A simple example client, using the embedded MySQL server library*/ #include #include #include #include MYSQL *db_connect(const char *dbname);void db_disconnect(MYSQL *db);void db_do_query(MYSQL *db, const char *query); const char *server_groups[] = { "test2_libmysqld_SERVER", "embedded", "server", NULL}; intmain(int argc, char **argv){ MYSQL *one, *two; /* mysql_server_init() must be called before any other mysql * functions. * * You can use mysql_server_init(0, NULL, NULL), and it * initializes the server using groups = { * "server", "embedded", NULL * }. * * In your $HOME/.my.cnf file, you probably want to put: [test2_libmysqld_SERVER]language = /path/to/source/of/mysql/sql/share/english * You could, of course, modify argc and argv before passing * them to this function. Or you could create new ones in any * way you like. But all of the arguments in argv (except for * argv[0], which is the program name) should be valid options * for the MySQL server. * * If you link this client against the normal mysqlclient * library, this function is just a stub that does nothing. */ mysql_server_init(argc, argv, (char **)server_groups); one = db_connect("test"); two = db_connect(NULL); db_do_query(one, "SHOW TABLE STATUS"); db_do_query(two, "SHOW DATABASES"); mysql_close(two); mysql_close(one); /* This must be called after all other mysql functions */ mysql_server_end(); exit(EXIT_SUCCESS);} static voiddie(MYSQL *db, char *fmt, ...){ va_list ap; va_start(ap, fmt); vfprintf(stderr, fmt, ap); va_end(ap); (void)putc('\n', stderr); if (db) db_disconnect(db); exit(EXIT_FAILURE);} MYSQL *db_connect(const char *dbname){ MYSQL *db = mysql_init(NULL); if (!db) die(db, "mysql_init failed: no memory"); /* * Notice that the client and server use separate group names. * This is critical, because the server does not accept the * client's options, and vice versa. */ mysql_options(db, MYSQL_READ_DEFAULT_GROUP, "test2_libmysqld_CLIENT"); if (!mysql_real_connect(db, NULL, NULL, NULL, dbname, 0, NULL, 0)) die(db, "mysql_real_connect failed: %s", mysql_error(db)); return db;} voiddb_disconnect(MYSQL *db){ mysql_close(db);} voiddb_do_query(MYSQL *db, const char *query){ if (mysql_query(db, query) != 0) goto err; if (mysql_field_count(db) > 0) { MYSQL_RES *res; MYSQL_ROW row, end_row; int num_fields; if (!(res = mysql_store_result(db))) goto err; num_fields = mysql_num_fields(res); while ((row = mysql_fetch_row(res))) { (void)fputs(">> ", stdout); for (end_row = row + num_fields; row /dev/null))# FreeBSDLDFLAGS += -pthreadelse# Assume LinuxLDLIBS += -lpthreadendif # This works for simple one-file test programssources := $(wildcard *.c)objects := $(patsubst %c,%o,$(sources))targets := $(basename $(sources)) all: $(targets) clean: rm -f $(targets) $(objects) *.core
我们鼓励所有人在GPL或兼容许可的旗帜下通过发布代码来推广免费软件。对于有能力完成该类事项的人员,也可以选择从MySQL AB购买MySQL的商用许可。详情请参见http://www.mysql.com/company/legal/licensing/。
发表评论
-
windows下进程间通信的
2012-01-20 08:55 546windows下进程间通信的 2010年09月04日 w ... -
深入探究 Win32 PE 文件格式
2012-01-20 08:55 646深入探究 Win32 PE 文件格 ... -
如何编写PHP扩展
2012-01-20 08:55 677如何编写PHP扩展 2010年0 ... -
C++操作MySQL (The MySQL C API)
2012-01-20 08:55 893C++操作MySQL (The MySQL C API) 2 ... -
flex builder 5
2012-01-19 13:59 765flex builder 5 2011年08月03日 a ... -
导出Flex组件为jpg图片
2012-01-19 13:59 829导出Flex组件为jpg图片 2011年03月10日 前 ... -
想开始整整SmartRcP Flex + Java 开发GUI程序
2012-01-19 13:59 416想开始整整SmartRcP Flex + Java 开发GUI ... -
flex 3如何通过iframe嵌入html网页
2012-01-19 13:59 706flex 3如何通过iframe嵌入html网页 2011年 ... -
flex 客户端缓存 module swf(转)
2012-01-19 13:59 623flex 客户端缓存 module swf ... -
"043d0df76"指令引用的"0x00000013"内存,该内存不能为"read"
2012-01-17 03:49 569"043d0df76"指令引 ... -
引用的“0x00000000”内存,该内存不能为“read”或“written
2012-01-17 03:49 930引用的“0x00000000”内存,该内存不能为“read”或 ... -
0x000001b8指令引用的0x000001b8内存该内存不能为read
2012-01-17 03:49 7080x000001b8指令引用的0x0000 ... -
DX复习文档
2012-01-17 03:49 625DX复习文档 2011年12月19 ... -
电脑故障大全 6
2012-01-17 03:49 487电脑故障大全 6 2011年05 ... -
CKP.CMP工作原理===
2012-01-16 02:35 1371CKP.CMP工作原理=== 2010年02月27日 传 ... -
名+解
2012-01-16 02:35 489名+解 2012年01月04日 ... -
数控机床电气控制课程作业(三)
2012-01-16 02:34 1094数控机床电气控制课程 ... -
哈哈 电控
2012-01-16 02:34 566哈哈 电控 2010年06月21 ...
相关推荐
【VC++通过API连接MySQL数据库】知识详解 在VC++中使用API连接MySQL数据库是一项常见的任务,这使得C++应用程序能够直接与MySQL数据库进行交互。本文将深入探讨如何实现这一过程,包括安装MySQL服务器、配置环境...
本篇文章将详细探讨如何使用VC++这一经典的C++集成开发环境来实现与MySQL数据库的连接和数据读取。我们将深入讨论三种不同的方法:ODBC(Open Database Connectivity)、ADO(ActiveX Data Objects)以及CAPI...
本案例专注于使用Visual C++ 6.0(简称VC++ 6.0)这个古老的但仍然有其价值的IDE,来连接和操作MySQL数据库。这个"VC++ 6.0连接MySQL源代码案例"为初学者提供了一个很好的学习平台,让我们深入探讨其中涉及的知识点...
### 在VC6中使用C API方式连接MySQL数据库 #### 一、环境配置 为了在Visual C++ 6.0(简称VC6)中使用C API连接MySQL数据库,首先需要完成必要的环境配置工作。 1. **下载MySQL Connector/C**: 从MySQL官网下载...
2. 数据库驱动:ODBC需要安装相应的数据库驱动,如SQL Server ODBC驱动或MySQL ODBC驱动,以便VC++应用程序通过ODBC API与特定数据库通信。 3. ADO(ActiveX Data Objects):微软还提供了更高层次的数据访问接口...
在C程序中,使用Mysql的API函数连接Mysql数据库,包括连接数据库、执行SQL语句、查询数据等。通过使用Mysql的API函数,可以实现C语言连接Mysql数据库的功能。 五、知识点总结 * Mysql安装和配置 * VC++中创建C程序...
标题中的“VC++6.0中用ODBC连接mysql数据库”指的是使用Visual C++ 6.0编程环境,通过开放数据库连接(ODBC)技术来与MySQL数据库建立连接,实现数据的读取、写入等操作。ODBC是微软提供的一种数据库访问接口,允许...
SQL 的 C API 来在 VC++6.0 或 2005 开发环境中与 MySQL 数据库进行交互。首先,我们需要配置开发环境,确保编译器能够找到必要的头文件和库文件。 一、开发环境的配置 对于 VC++ 4.1/5.0/6.0: 1. 在“Tools”...
在VC++6.0中,使用ODBC(Open Database Connectivity)连接MySQL数据库是一个常见的任务,尤其是在开发Windows应用程序时。ODBC是一种标准接口,允许不同数据库系统之间的互操作性。以下是一份详细的步骤指南,帮助...
在MFC中,首先需要创建`CDatabase`对象,并用`OpenEx`或`Open`函数连接到ODBC数据源。这需要指定DSN(数据源名称),用户名和密码等信息。例如: ```cpp CDatabase db; if (!db.OpenEx("DSN=MyDataSource;UID=...
### 基于VC++编程的MFC与MySQL数据库交互 #### 一、概述 本文主要探讨了在Visual C++(VC++)环境下利用MFC框架进行MySQL数据库的读写操作。通过MFC提供的ODBC接口,可以实现对MySQL数据库的操作,包括数据的查询...
首先,`mysql.h`是MySQL C API的头文件,它提供了所有必要的函数声明和数据结构定义,用于编写连接和操作MySQL数据库的应用程序。开发者可以通过包含这个头文件来使用MySQL的API接口,如`mysql_init()`, `mysql_real...
本文将详细介绍如何使用C++语言来连接MySQL数据库,主要介绍两种方式:利用ADO(ActiveX Data Objects)连接以及使用MySQL提供的API函数进行连接。 #### 二、ADO连接MySQL数据库 **1. ADO简介** ADO是一种用于...
2. SQL语句:编写SQL语句进行数据查询、插入、更新和删除,VC++通过API函数调用执行SQL。 3. 用户界面:利用MFC(Microsoft Foundation Classes)框架,创建图形用户界面,提供友好的交互体验。 五、系统开发流程 1...
在VC++中,通过建立ODBC数据源,我们可以连接到不同的数据库管理系统,例如MySQL、Oracle、SQL Server等。 3. **ADO对象模型**:ADO是微软提供的一个更高级别的接口,它封装了ODBC的复杂性,使得与数据库的交互更为...
在VC++环境中,使用MySQL API连接数据库是一种常见的方式,尤其对于开发C++应用程序时需要与MySQL数据库进行交互的情况。MySQL API提供了丰富的函数和结构,使得开发者可以直接在代码中执行SQL语句,处理结果集,...
### 在VS2010环境下使用MFC连接MySQL数据库 #### 一、环境搭建与配置 在本章节中,我们将详细介绍如何在Visual Studio 2010 (VS2010)环境中使用Microsoft Foundation Classes (MFC)来连接MySQL数据库,并实现基本...
在VC++环境下进行MYSQL数据库编程是一项常见的任务,尤其是在开发Windows应用程序时。这涉及到使用C++语言与MySQL数据库服务器进行交互,实现对数据库的各种操作。在这个过程中,开发者通常会利用MySQL提供的C API...
1. **连接数据库**:使用MySQL的API函数`mysql_init()`初始化一个MYSQL结构体,然后用`mysql_real_connect()`建立与数据库服务器的连接,指定主机名、用户名、密码和数据库名。 2. **执行SQL查询**:通过`mysql_...