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

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)



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值