|
|
51CTO旗下网站
|
|
移动端

PHP的MySQL库之Pdo-Mysql与Mysqli性能对比

本文主要对PHP的MySQL库:Pdo-Mysql与Mysqli性能进行了对比,包括执行速度的快慢以及对WEB服务器的影响等方面,希望能够对您有所帮助。

作者:佚名来源:火魔网|2011-08-05 10:01

我们知道,LAMP(Linux + Apache + Mysql + PHP)是一种很常用的WEB服务器搭配。PHP中有很多MySQL库以方便我们的使用,比如说:Pdo-MysqlMysqli等等。那么究竟哪种方式性能***呢?本文我们对以上的连接方式作了性能对比试验:

1、建一个Mysql数据库,新建一张InnoDB表(参考某项目的核心表),然后用存储过程生成100万条数据。

2、搭一PHP环境,每次访问会随机查询数据库里的一条数据。

3、访问完成后验证查询结果的正确性。

Pdo-Mysql长连接 $dbh = new PDO(……,array(PDO::ATTR_PERSISTENT => true));

Pdo-Mysql短连接 $dbh = new PDO($host, $username, $password);

Mysqli $dbh = new mysqli($host,$username,$password,$dbname,$port);

Mysqli_connect $dbh = mysqli_connect($host,$username,$password,$dbname,$port);

自带 $dbh = mysql_connect($host,$username,$password);

结论:

1、使用Pdo-Mysql的长连接方式,性能***;

2、Mysqli的性能要优于使用Pdo-Mysql即时连接;

3、Pdo-Mysql即时连接性能同使用“自带”方式没有明显差异。

附,Pdo-Mysql与Mysqli的每秒事务数图:

PHP的MySQL库之Pdo-Mysql与Mysqli性能对比

附,对应时间段Web服务器的内存使用图:

PHP的MySQL库之Pdo-Mysql与Mysqli性能对比

从上面两个图可以看出:

1. Pdo-Mysql之所以比Mysqli快,是由于Pdo-Mysql对数据库的操作比Mysqli要少;

2. 在Pdo-Mysql使用了长连接的测试中,Web服务器内存持续上涨。

(简单查了一下,是Aapche服务的httpd进程内存上涨,再跟进去模块名显示[匿名],后续再继续查一下原因)

那么单纯从性能角度看,Pdo-Mysql长连接性能***,但有何弊端还有待查证。

关于PHP中MySQL库的Pdo-Mysql与Mysqli性能对比的知识就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. MySQL数据库如何恰到好处地使用索引?
  2. MySQL使用Amoeba作为Proxy时的注意事项
  3. MySQL数据库binlog记录的时间戳失序的原因
  4. MySQL数据库目录结构及常用命令的使用总结篇
  5. 以MySQL为例介绍数据库测试工具dbmonster的使用
【责任编辑:赵鹏 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

16招轻松掌握PPT技巧

16招轻松掌握PPT技巧

GET职场加薪技能
共16章 | 晒书包

289人订阅学习

20个局域网建设改造案例

20个局域网建设改造案例

网络搭建技巧
共20章 | 捷哥CCIE

645人订阅学习

WOT2019全球人工智能技术峰会

WOT2019全球人工智能技术峰会

通用技术、应用领域、企业赋能三大章节,13大技术专场,60+国内外一线人工智能精英大咖站台,分享人工智能的平台工具、算法模型、语音视觉等技术主题,助力人工智能落地。
共50章 | WOT峰会

0人订阅学习

读 书 +更多

嬴在用户:Web人物角色创建和应用实践指南

您如何保证您的网站确实给予用户他们所需要的,并对您产生商业成果?您需要了解谁是您的用户,您的用户的目标、行为和观点是什么,还要把他...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO播客