PDO数据连接持久化性能测试

时间:2022-06-01 18:33:42

PDO数据连接持久化可以有效地提升连接数据库的效率。前面文章中做过测试,连接1000次数据库需要使用100秒,一次连接需要0.1秒。如果在项目中,凡是需要连接数据库的地方都需要创建一次连接无疑会对系统的性能带来很大的损失。所以在PDO中可以进行数据库连接的持久化属性设置。所谓的数据库连接持久化就是创建一次连接之后就把该连接直接缓存,以后再次用到连接数据库的时候直接读取缓存而无需再次创建。

具体代码测试:

创建1000次连接:

set_time_limit(0);
$begiontime=microtime(true);
for($i=0;$i<1000;$i++) {
$pdo = new PDO("mysql:host=localhost;dbname=myphp", 'root', '123456'));
}
$endtime=microtime(true);
$times=$endtime-$begiontime;
echo $times;

返回结果:

101.266328634876



使用数据库连接持久化之后:

set_time_limit(0);
$begiontime=microtime(true);
for($i=0;$i<1000;$i++) {
$pdo = new PDO("mysql:host=localhost;dbname=myphp", 'root', '123456', array(PDO::ATTR_PERSISTENT => true));
}
$endtime=microtime(true);
$times=$endtime-$begiontime;
echo $times;


返回结果:

0.15400886535645


由此可见,数据库连接持久化在第一次创建连接之后,就不用再次创建连接而是直接读取缓存。

具体操作只是在PDO的构造方法中加一个数组类型的参数。

array(PDO::ATTR_PERSISTENT => true)