简介:这是php中关于mysqli和mysql区别的一些知识点整理的详细页面,介绍了和php,有关的知识、技巧、经验,和一些php源码等。 class='pingjiaF' frameborder='0' src='http://biancheng.dnbcw.info/pingjia.php?id=346697' scrolling='no'>
看书、看视频的时候一直没有搞懂mysqli和mysql到底有什么区别。于是今晚“谷歌”一番,整理一下。
一:
PHP-MySQL 是 PHP 操作 MySQL �料�最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相���的功能,就 Extension 而言,本身也增加了安全性。而 PDO (PHP Data Object) �是提供了一� Abstraction Layer �操作�料�,用�的其�看不出�有有什�差�,所以就直接看程式吧…
首先,先�看一段用 PHP-MySQL �成的程式�,��的�例常用在世界各地:
view source
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() �解�����,不���一搞,整��述��得��且�陋,而且如果�位多了,可以想��是怎�的情形…
1
2
3
$query = sprintf("SELECT * FROM users WHERE user='%s' AND password='%s'",
4
mysql_real_escape_string($user),
5
mysql_real_escape_string($password));
6
7
mysql_query($query);
8
9
?>
在 PHP-MySQLi 中有了不少�步,除了透� Bind Column �解�上述��,而且也多援 Transaction, Multi Query ,�且同�提供了 Object oriented style (下面�段 PHP-MySQLi �例的�法) 和 Procedural style (上面 PHP-MySQL �例的�法)���法…等等。
01
02
03
$mysqli =new mysqli($db_host,$db_user,$db_password,$db_name);
04
05
$sql ="INSERT INTO `users` (id, name, gender, location) VALUES (?, ?, ?, ?)";
06
$stmt =$mysqli->prepare($sql);
07
08
$stmt->bind_param('dsss',$source_id,$source_name,$source_gender,$source_location);
09
10
$stmt->execute();
11
12
$stmt->bind_result($id,$name,$gender,$location);
13
14
while ($stmt->fetch())
15
{
16
echo $id .$name .$gender .$location;
17
}
18
19
$stmt->close();
20
$mysqli->close();
21
22
?>
但看到��又��了一些缺�,例如得 Bind Result,��就有�多�,不��其����要,因�最大的���是在於�不是一�抽象(Abstraction)的方法,所以�後端更��料�的�候,就是痛苦的�始…
於是 PDO 就出�了(��:目前 Ubuntu 和 Debian ��,PDO ��有直接的套件可以安�,而是必�透� PECL 安�)。
roga@carlisten-lx:~$ pecl search pdo
=======================================
Package Stable/(Latest) Local
PDO 1.0.3 (stable) PHP Data Objects Interface.
PDO_4D 0.3 (beta) PDO driver for 4D-SQL database
PDO_DBLIB 1.0 (stable) FreeTDS/Sybase/MSSQL driver for PDO
PDO_FIREBIRD 0.2 (beta) Firebird/InterBase 6 driver for PDO
PDO_IBM 1.3.2 (stable) PDO driver for IBM databases
PDO_INFORMIX 1.2.6 (stable) PDO driver for IBM Informix INFORMIX databases
PDO_MYSQL 1.0.2 (stable) MySQL driver for PDO
PDO_OCI 1.0 (stable) Oracle Call Interface driver for PDO
PDO_ODBC 1.0.1 (stable) ODBC v3 Interface driver for PDO
PDO_PGSQL 1.0.2 (stable) PostgreSQL driver for PDO
PDO_SQLITE 1.0.1 (stable) SQLite v3 Interface driver for PDO
pdo_user 0.3.0 (beta) Userspace driver for PDO
�透� PECL 安��好後,就可以透�以下方式�操作�料�:
01
02
03
$dsn ="mysql:host=$db_host;dbname=$db_name";
04
$dbh =new PDO($dsn,$db_user,$db_password);
05
06
$sql ="SELECT `name`, `location` FROM `users` WHERE `location` = ? , `name` = ?";
07
$sth =$dbh->prepare($sql);
08
09
$sth->execute(array($location,$name));
10
11
$result =$sth->fetch(PDO::FETCH_OBJ);
12
echo $result->name .$result->location;
13
14
$dbh = NULL;
15
16
?>
乍看之下,PDO 的程式�好像也�有比�短,那到底好�是什�呢?
1. PDO �接�料��透� Connection String ��定�接何��料�。
2. PDO 可以透� PDO::setAttribute ��定���的�定,像是 Persistent Connection, 回���的方式(Exception, E_WARNING, NULL)。甚至是回��位名�的大小�…等等。
2. PDO 支援 Bind Column 的功能,除了基本的 Prepare, Execute 以外,也可以 Bind �一�位,�且指定�位型�。
4. PDO 是 Abstraction Layer 所以就算更��存媒介,需要花的功夫比起�是最少的。
可惜的是,�管�些�西都已�出�很久了,但�是不�大�化。我想或�是肇因於大家��看坊�的�籍��,但那些�本往往只�介�最��最��的方式。�致很多人�是在用 MySQL ��方直接��料�。
不�,目前��我�人�是最喜�透� DBI ��接�料�,像是 ActiveRecord 以及 Propel ORM(Object-Relational Mapping)。
例如�以 ActiveRecord �例,如果要����的 SQL �述…
INSERT INTO `users` (id, name, gender, location) VALUES(1, 'roga', 'male', 'tpe')
以 PDO ��是:
1
2
3
$sql ="INSERT INTO `users` (id, name, gender, location) VALUES(?, ?, ?, ?)";
4
$sth =$dbh->prepare($sql);
5
6
$sth->execute(array(1,'roga','male','tpe'));
7
8
?>
但以 ActiveRecord ��的�,�是:
01
02
03
$user =new User();
04
05
$user->id = 1;
06
$user->name ='roga';
07
$user->gender ='male';
08
$user->location ='tpe';
09
10
$user->save();
11
12
?>
後者在�法上是不是��很多呢,而且也大幅降低� SQL �言的依�性!(不同�料�� SQL �作的��可�考 Comparison of different SQL implementations)