文档章节

php中使用mysql、mysqli、pdo的比较

杭城小刘
 杭城小刘
发布于 2015/07/02 10:15
字数 868
阅读 64
收藏 0

        普通的mysql方法在安全性方面应该不是很好,每次需要考虑sql注入的问题,而且速度不是很赞。而mysqli是在mysql基础上进行改进的一次,较好的解决了sql注入问题。

        pdo则是最新的数据库抽象方法,pdo高度抽象了数据库操作,项目使用pdo方法可以方便的进行迁移,在不同的数据库之间进行迁移。

        在高负载的情况下.PDO开启长连接能够得到一个相对稳定的负载“值”。但是效率却不是最高的。
mysql最快。mysqli其次。只是mysql和mysqli在高并发、系统高负载的时候。其所承担的负载也是很可观的。PDO则不会。


书写风格 面向对象 抛异常
php_mysqli   函数名用下划线,比如fetch_all  可以oop,也可以opp 否,只能false
pdo 函数名用驼峰,比如fetchAll oop 可以throw,也可false或false加warnnig
php_pgsql 函数名用下划线,比如pg_fetch_all opp 否,只能false

其次pdo是面向对象的,当有错误的时候可以抛出异常,而且可以自定义异常抛出。


php_mysqli 与 pdo 性能对比:(查找自互联网)

  PHP的mysqli扩展 PDO (使用PDO MySQL驱动和MySQL Native驱动) PHP的mysql扩展
引入的PHP版本 5.0 5.0 3.0之前
PHP5.x是否包含
MySQL开发状态 活跃 在PHP5.3中活跃 仅维护
在MySQL新项目中的建议使用程度 建议 - 首选 建议 不建议
API的字符集支持
服务端prepare语句的支持情况
客户端prepare语句的支持情况
存储过程支持情况
多语句执行支持情况 大多数
是否支持所有MySQL4.1以上功能 大多数

PDO使用说明:

PDO::prepare()

官方文档:http://www.php.net/manual/zh/pdo.prepare.php

适用:多次查询使用相同的条件字段和结果字段。这时候比PDO::query()性能高。

转义:value无需手动转义,PDO会自动进行转义,不用担心SQL注入。(开启query log可以看到语句的确已转义)

缺点:由于标识符(列名表名)是手写的SQL,要自己加引用符反勾号`。

PDO::prepare()模拟处理的时候不会通过数据库,所以不知道语法错误,不会返回错误或抛异常。什么时候是真处理,什么时候是模拟处理, 官方手册中未找到说明。输入任意的SQL都不出错……所以目前不要指望prepare返回错误,PDOStatement::execute()时才会返 回错误。http://www.php.net/manual/zh/pdo.prepare.php

 补充:这里给出mysql、mysqli、pdo的基本用法

<?php
//mysql方法
    $dbname='db_pet';
    $username='root';
    $password='playboy';
    mysql_connect('localhost',$username,$password);
    mysql_select_db($dbname);
    $res=mysql_query('select password from user where username="home"');
    $row=mysql_fetch_row($res);
    echo $row[0] ;


echo '<hr/>';

//mysqli方法
    $con=new MySQLi('localhost',$username,$password,$dbname);
    $res2=$con->query('select email from user where username ="home"');
    $row2=$res2->fetch_array();
    echo $row2[0];
    
echo '<hr/>';



//pdo方法
    try{
        $pdo=new PDO('mysql:host=localhost;dbname=db_pet','root','playboy');
        $sql='select email from user where username=?';
        $stmt=$pdo->prepare($sql);
        $stmt->execute(array('home'));
        echo $stmt->rowCount();
    }catch(PDOException $e){
        echo $e->getMessage();
    }    

?>


 



 


© 著作权归作者所有

上一篇: mongdb的基本使用
下一篇: Mac下使用git
杭城小刘

杭城小刘

粉丝 27
博文 116
码字总数 81048
作品 0
杭州
iOS工程师
私信 提问
php连接mysql数据库的几种方式(mysql、mysqli、pdo)

php连接mysql数据库的几种方式(mysql、mysqli、pdo) www.111cn.net 编辑:flyfox 来源:转载 php与mysql的连接有三种API接口,分别是:PHP的MySQL扩展 、PHP的mysqli扩展 、PHP数据对象(PDO) ,...

DanEcho
2016/11/10
0
0
PHP-MySQL连接问题

在使用PHP去连接MySQL数据库时,有三种(流行的)方法: PHP-MySQL, PHP-MySQLi, PDO, 有一些需要注意的地方: 1, 当我们谈论MySQL的时候,更多的是指关系型数据库; 2,PHP-MySQL和PHP-MySQLi是...

vinci321
2018/03/08
0
0
PHP 5.3.0以上推荐使用mysqlnd驱动

1.什么是mysqlnd驱动? PHP手册上的描述: MySQL Native Driver is a replacement for the MySQL Client Library (libmysql). MySQL Native Driver is part of the official PHP sources as of......

月影又无痕
2013/06/27
0
1
PHP连接Mysql常用API(mysql,mysqli,pdo)的区别

什么是API? 一 个应用程序接口(Application Programming Interface的缩写),定义了类,方法,函数,变量等等一切 你的应用程序中为了完成特定任务而需要调用的内容。在PHP应用程序需要和数...

Junn
2014/03/03
0
1
LAMP架构(PHP的安装解析)

PHP官网www.php.net 当前主流版本为5.6/7.1 一,下载php包: wget http://cn2.php.net/distributions/php-.tar.gz 二,解压php包: tar zxf php-.tar.gz 进入php文件中 cd php- 三,开始编译...

小新锐
2017/12/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

最新【从零单排】系列流出,教你如何实现字典存储结构

昨天在星球的【从零单排】系列分享了一篇【字典存储结构的实现方式】,我觉得这篇文章写的还是蛮好的,就分享给大家了。 但由于篇幅太长了,微信没办法全部传上来,如果你觉得内容还不错,想...

上海小胖
36分钟前
0
0
JWT学习总结

官方 https://jwt.io 英文原版 https://www.ietf.org/rfc/rfc7519.txt 或 https://tools.ietf.org/html/rfc7519 中文翻译 https://www.jianshu.com/p/10f5161dd9df 1. 概述 JSON Web Token(......

冷基
今天
5
0
AOP的学习(1)

AOP 理解AOP编程思想(面向方法、面向切面) spring AOP的概念 方面 -- 功能 目标 -- 原有方法 通知 -- 对原有方法增强的方法 连接点 -- 可以用来连接通知的地方(方法) 切入点 -- 将用来插入...

太猪-YJ
今天
5
0
一张图看懂亮度、明度、光度、光亮度、明亮度

亮度、明度、光亮度,Luminance和Brightness、lightness其实都是一个意思,只是起名字太难了。 提出一个颜色模型后,由于明度的取值与别人的不同,为了表示区别所以就另想一个词而已。 因此在...

linsk1998
昨天
11
0
Python应用:python链表示例

前言 python链表应用源码示例,需要用到python os模块方法、函数和类的应用。 首先,先简单的来了解下什么是链表?链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是...

python小白1
昨天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部