php中MYSQL、MYSQLi和PDO的用法和区别:

PHPMySQL扩展(优缺点)

设计开发允许PHP应用与MySQL数据库交互的早期扩展。mysql扩展提供了一个面向过程的接口;

并且是针对MySQL4.1.3或更早版本设计的。因此,这个扩展虽然可以与MySQL4.1.3或更新的数 ;

据库服务端 进行交互,但并不支持后期MySQL服务端提供的一些特性。

PHP的mysqli扩展

mysqli扩展,我们有时称之为MySQL增强扩展,可以用于使用 MySQL4.1.3或更新版本中新的高级特性;

mysqli扩展在PHP 5及以后版本中包含;

mysqli扩展有一系列的优势,相对于mysql扩展的提升主要有:面向对象接口、 prepared语句支持、多语句执行支持、事务支持、增强的调试能力、嵌入式服务支持。

PHP数据对象(PDO)

PHP数据对象,是PHP应用中的一个数据库抽象层规范。PDO提供了一个统一的API接口可以,使得你的PHP应用不去关心具体要 连接的数据库服务器系统类型。也就是说,如果你使用PDO的API,可以在任何需要的时候无缝切换数据库服务器

Mysql连接:

<?php
$conn= @ mysql_connect("localhost", "root", "") or die("数据库连接错误");
mysql_select_db("bbs", $conn);
mysql_query("set names 'utf8'");
echo
"数据库连接成功";
?>


Mysqli连接:

    1、普通连接:


<?php
$conn= mysqli_connect('127.0.0.1', 'root', '', 'root');
if(!$conn){
    die("数据库连接错误". mysqli_connect_error());
}else{
    echo"数据库连接成功";
}
?>

    2、OOP连接:

$mysqli = new MYSQLi("127.0.0.1","root","root");
    $mysqli->set_charset("utf8");
    $mysqli->select_db("miaosha");
    $mysqli->query($sql);
    $mysqli->affected_rows;
    $mysqli->fetch_assoc();
PDO连接:
    try{
        $pdo = new PDO("mysql:host=127.0.0.1;dbname=miaosha","root","root");
        }catch(PDOException $e){
        echo "数据库连接失败";
        }
        echo "数据库连接成功";
$pdo->prepare($sql);

以下是Mysql、Mysqli、Pdo三种方式的区别对比


PHP-MySQL 是 PHP 操作 MySQL 资料库最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相对进阶的功能,就 Extension 而言,本身也增加了安全性。而 PDO (PHP Data Object)

1.mysql与mysqli

mysqli是php5提供的新函数库,(i)表示改进,其执行速度更快.当然也更安全

mysql是非持继连接函数而mysqli是永远连接函数。也就是说,mysql每次链接都会打开一个连接的进程而mysqli多次运行mysqli将使用同一连接进程,从而减少了服务器的开销 有些朋友在编程的时候,使用new mysqli(‘localhost’, usenamer’, ‘password’, ‘databasename’);总是报错,Fatal error: Class ‘mysqli’ not found in d:\…

mysqli类不是php自带的吗?

不是默认开启的,win下要改php.ini,去掉php_mysqli.dll前的#;,Linux下要把mysqli编译进去。

一:Mysqli.dll是一个允许以对象的方式或者过程操作数据库的,它的使用方式也很容易。这里就几个常

<?php 
$mysqli = new mysqli("localhost", "my_user", "my_password", "world"); 
 
/* check connection */ 
if (mysqli_connect_errno()) { 
printf("Connect failed: %sn", mysqli_connect_error()); 
exit(); 
} 
 
/* Insert rows */ 
$mysqli->query("CREATE TABLE Language SELECT * from CountryLanguage"); 
printf("Affected rows (INSERT): %dn", $mysqli->affected_rows); 
 
$mysqli->query("ALTER TABLE Language ADD Status int default 0″); 
 
/* update rows */ 
$mysqli->query("UPDATE Language SET Status=1 WHERE Percentage > 50″); 
printf("Affected rows (UPDATE): %dn", $mysqli->affected_rows); 
 
/* delete rows */ 
$mysqli->query("DELETE FROM Language WHERE Percentage < 50″); 
printf("Affected rows (DELETE): %dn", $mysqli->affected_rows); 
 
/* select all rows */ 
$result = $mysqli->query("SELECT CountryCode FROM Language"); 
printf("Affected rows (SELECT): %dn", $mysqli->affected_rows); 
 
$result->close(); 
 
/* Delete table Language */ 
$mysqli->query("DROP TABLE Language"); 
 
/* close connection */ 
$mysqli->close(); 
?><?php
mysql_connect($db_host, $db_user, $db_password);
mysql_select_db($dn_name);
$result= mysql_query("SELECT `name` FROM `users` WHERE `location` = '$location'");
while
($row= mysql_fetch_array($result, MYSQL_ASSOC)){
    echo $row['name'];
}
mysql_free_result($result);
?>
<?php
mysql_connect($db_host, $db_user, $db_password);
mysql_select_db($dn_name);
$result= mysql_query("SELECT `name` FROM `users` WHERE `location` = '$location'");
while
($row= mysql_fetch_array($result, MYSQL_ASSOC)){
    echo $row['name'];
}
mysql_free_result($result);
?>

其实背后有些学问… 这种方式不能 Bind Column ,以前例的 SQL 叙述来说,$location 的地方容易被 SQL Injection。后来于是发展出了 mysql_escape_string() (备注:5.3.0之后弃用) 以及 mysql_real_escape_string()来解决这个问题,不过这麽一搞,整个叙述会变得複杂且丑陋,而且如果栏位多了,可以想见会是怎样的情形…

<?php
$query = sprintf("SELECT * FROM users WHERE user='%s' AND password='%s'"; 
mysql_real_escape_string($user);
mysql_real_escape_string($password)); 
mysql_query($query);
?>

在 PHP-MySQLi 中有了不少进步,除了透过 Bind Column 来解决上述问题,而且也多援 Transaction, Multi Query ,并且同时提供了 Object oriented style (下面这段 PHP-MySQLi 范例的写法) 和 Procedural style

在 PHP-MySQLi 中有了不少进步,除了透过 Bind Column 来解决上述问题,而且也多援 Transaction, Multi Query ,并且同时提供了 Object oriented style (下面这段 PHP-MySQLi 范例的写法) 和 Procedural style

<?php 
$mysqli = new mysqli($db_host, $db_user, $db_password, $db_name); 
$sql = "INSERT INTO `users` (id, name, gender, location) VALUES (?, ?, ?, ?)"; 
$stmt = $mysqli->prepare($sql); 
$stmt->bind_param('dsss', $source_id, $source_name, $source_gender, $source_location); 
$stmt->execute(); 
$stmt->bind_result($id, $name, $gender, $location); 
while ($stmt->fetch()){ 
    echo $id . $name . $gender . $location; 
} 
$stmt->close(); 
$mysqli->close();
?>



但看到这边又发现了一些缺点,例如得 Bind Result,这个就有点多馀,不过这其实无关紧要,因为最大的问题还是在于这不是一个抽象(Abstraction)的方法,所以当后端更换资料库的时候,就是痛苦的开始… 于是 PDO 就出现了

<?php
    $mysqli = @new mysqli("localhost", "root", "", "design");
    //如果连接错误
    if(mysqli_connect_errno()){
        echo "连接数据库失败:".mysqli_connect_error();
        $mysqli=null;
        exit;
    }
    //准备好一条语句放到服务器中,插入语句
    $sql = "insert into designer(name, email) values(?, ?)";
    //生成预处理语句
    $stmt = $mysqli->prepare($sql);
    //给占位符号每个?号传值(绑定参数) i  d  s  b,第一个参数为格式化字符,ss代表两个字符串,d代表数字
    $stmt->bind_param("ss", $name, $email);
    //为变量赋值
    $name = "Mike";
    $email = "mike@live.cn";
    //执行
    $stmt->execute();
    //为变量赋值
    $name = "Larry";
    $email = "larry@live.cn";
    //执行
    $stmt->execute();
    //最后输出
    echo "最后ID".$stmt->insert_id."<br>";
    echo "影响了".$stmt->affected_rows."行<br>";
    //关闭数据库连接
    $mysqli->close();
?>



在链接MySQL上几乎没有区别。PDO的性能损失完全可以忽略不计。

但是却有非常多的操作却是MySQL扩展库所不具备的:

1:PDO真正的以底层实现的统一接口数库操作接口

2:PDO支持更高级的DB特性操作,如:存储过程的调度等,mysql原生库是不支持的.

3:PDO是PHP官方的PECL库,兼容性稳定性必然要高于MySQL Extension,可以直接使用 pecl upgrade pdo 命令升级. 

PHP6默认也是使用PDO进行数据库链接,MySQL Extension会作为辅助。所以我们在日常项目中,如果环境允许,尽可能去使用PDO来进行MySQL数据库操作。