基于MysqlConnector/C++的数据库连接池的实现
1. 连接池的介绍: 1.1 应用背景: 一般的应用 程序 都会访问到数据库,在程序访问数据库的时候,每一次数据访问请求都必须经过 下面几个步骤: 建立数据库连接,打开数据库,对数据库中的数据进行操作,关闭数据库连接。而建立数据库连接和打开数据库是一件很消耗资源并且费时的工作,如果在系统中很频繁的发生这种数据库连接,必然会影响到系统的性能,甚至会导致系统的崩溃。 1.2 技术思想: 在 系统 初始化阶段,建立一定数量的数据库连接对象 ( C onnection) ,并将其存储在连接池 中定义的 容器中。当有数据库访问请求时,就从连接池中的这个容器中拿出一个连接;当容器中的连接已经用完,并且还没有达到系统定义的最大连接数时,可以再创建一个新的连接 , 当当前使用的连接数达到最大连接数时,就要等待其他访问请求将连接放回容器后才能使用。当使用完连接的时候, 必须 将连接放回容器中,这样不同的数据库访问请求就可以共享这些连接,通过 重复使用 这些已经建立的数据库连接,可以解决上节中说到的频繁 建立连接 的缺点,从而提高了系统的性能。 经过上述描述,我们可以归纳出数据库连接池的主要操作: (1) 首先建立一个数据库连接池对象 (2) 初始化 一定数量的数据库连接,放入连接池对象的容器中 (3) 当有数据库访问请求时,直接从连接池的容器中得到一个连接,这里出现三种情况: (a)