MySQL数据库接口在VC中的实际应用有哪些?

数据库 MySQL
以下的文章主要介绍的是MySQL数据库接口(ODBC API和C API)在VC中的实际应用,以下就是文章的具体内容的详细描述。

MySQL(和PHP搭配之最佳组合)数据库作为一种网络数据库性能十分出色,但其在应用软件中使用较少。本文将主要探讨MySQL数据库接口 ——(ODBC API和C API)在VC中的应用,并且形成一个类用以封装C API数据库接口的功能。

 利用MySQL(和PHP搭配之最佳组合)自带的C API函数实现数据库功能调用

由于各个数据库之间的差异,它们所提供的数据库功能也就各有不同。这样,通过ODBC API就不可能完全拥有所有的数据库功能,因而影响了程序对数据库的控制功能,也就不能充分发挥数据库的能力。并且这种统一的接口还是以损失效能为前提的,这就使数据库操作时间延长。所以,为了解决以上问题,MySQL(和PHP搭配之最佳组合)的制造商在提供ODBC驱动程序的基础上,还提供了各种编程环境下的API,其中包括C API。这些API函数很显然能尽可能地发挥数据库的能力,并减少数据库操作的延长时间,但却使程序的通用性受到严重影响。

MySQL(和PHP搭配之最佳组合)提供了一套C API函数,它由一组函数以及一组用于函数的数据类型组成,这些函数与MySQL(和PHP搭配之最佳组合) 服务器进行通信并访问MySQL数据库接口,可以直接操控数据库,因而显著地提高了操控效能。

C API数据类型包括:MySQL(和PHP搭配之最佳组合)(数据库连接句柄)、MySQL(和PHP搭配之最佳组合)_RES(查询返回结果集)、MySQL(和PHP搭配之最佳组合)_ROW(行集)、MySQL(和PHP搭配之最佳组合)_FIELD(字段信息)、MySQL(和PHP搭配之最佳组合)_FIELD_OFFSET(字段表的偏移量)、my_ulonglong(自定义的无符号整型数)等;

C API提供的函数包括:MySQL(和PHP搭配之最佳组合)_close()、MySQL(和PHP搭配之最佳组合)_connect()、MySQL(和PHP搭配之最佳组合)_query()、MySQL(和PHP搭配之最佳组合)_store_result()、MySQL(和PHP搭配之最佳组合)_init()等,其中MySQL(和PHP搭配之最佳组合)_query()最为重要,能完成绝大部分的数据库操控。

下面将具体讨论数据库操作类CDatabase通过C API的实现以及在VC中的应用。

查看max_connections、max_connections的办法见后。

 

如果 threads_connected == max_connections 时,数据库系统就不能提供更多的连接数了,这时,如果程序还想新建连接线程,数据库系统就会拒绝,如果程序没做太多的错误处理,就会出现类似强坛的报错信息。

因为创建和销毁数据库的连接,都会消耗系统的资源。而且为了避免在同一时间同时打开过多的连接线程,现在编程一般都使用所谓数据库连接池技术。

但数据库连接池技术,并不能避免程序错误导致连接资源消耗殆尽。

这种情况通常发生在程序未能及时释放数据库连接资源或其他原因造成数据库连接资源不能释放,但强坛系统估计不会发生这种低级的编程错误。

该错误的简便的检查办法是,在刷新强坛页面时,不断监视threads_connected的变化。如果max_connections足够大,而threads_connected值不断增加以至达到max_connections,那么,就应该检查程序了。当然,如果采用数据库连接池技术,threads_connected增长到数据库连接池的最大连接线程数时,就不再增长了。

 

从强坛出错的情况看,更大的可能性是数据库系统没能进行适当地配置。下面提出一点建议。供参考

让你们的工程师把MySQL(和PHP搭配之最佳组合)的最大允许连接数从默认的100调成32000。这就不会老出现连接过多的问题了。

 

查看max_connections

 

进入MySQL(和PHP搭配之最佳组合),用命令:show variables

查看MySQL数据库接口最大可连接数的变量值:max_connections

 

查看threads_connected

进入MySQL(和PHP搭配之最佳组合),用命令:show status

查看当前活动的连接线程变量值:threads_connected

 

 

设置max_connections

 

设置办法是在my.cnf文件中,添加下面的最后红色的一行:

  1. [MySQL(和PHP搭配之最佳组合)d]   
  2. port=3306   
  3. #socket=MySQL(和PHP搭配之最佳组合)   
  4. skip-locking   
  5. set-variable = key_buffer=16K   
  6. set-variable = max_allowed_packet=1M   
  7. set-variable = thread_stack=64K   
  8. set-variable = table_cache=4   
  9. set-variable = sort_buffer=64K   
  10. set-variable = net_buffer_length=2K   
  11. set-variable = max_connections=32000  

 

 

修改完毕后,重启MySQL(和PHP搭配之最佳组合)即可。当然,为了确保设置正确,应该查看一下max_connections。

注意:

1、虽然这里写的32000。但实际MySQL(和PHP搭配之最佳组合)服务器允许的最大连接数16384;

 

2、除max_connections外,上述其他配置应该根据你们系统自身需要进行配置,不必拘泥;

 

3、添加了最大允许连接数,对系统消耗增加不大。

 

4、如果你的MySQL(和PHP搭配之最佳组合)用的是my.ini作配置文件,设置类似,但设置的格式要稍作变通。

 

【编辑推荐】

  1. 对MySQL 中文乱码的解决方案的描述
  2. 查看MySQL连接数的实际操作流程
  3. MySQL数据库在实际应用一些方面的介绍
  4. MySQL数据库日志的文件维护流程
  5. MySQL 5.1在Linux下的正确安装
责任编辑:佚名 来源: 互联网
相关推荐

2009-03-17 09:28:22

接口VCMySQL

2010-06-07 16:22:55

MySQL数据库

2010-05-13 13:49:09

MySQL数据库

2010-05-28 11:41:46

MySQL数据库备份

2010-05-20 15:22:37

2010-05-21 16:33:02

MySQL数据库

2010-05-25 18:21:28

MySQL连接数据库

2010-07-06 15:02:12

SQL Server

2010-05-12 15:41:21

MySQL数据库

2010-05-19 17:35:35

2024-01-22 09:43:50

数据库方案

2010-08-20 13:45:43

DB2数据库

2010-05-06 15:44:08

Oracle Nvl函

2010-06-11 13:13:38

访问MySQL数据库

2010-05-25 14:42:14

MySQL 数据库

2010-08-02 09:10:45

JDBC连接DB2

2010-04-13 12:23:34

Oracle数据库

2010-06-17 10:02:12

SQL Server数

2010-03-30 11:15:26

Oracle数据库

2010-04-21 11:27:55

Oracle数据库
点赞
收藏

51CTO技术栈公众号