ci mysqli和mysql_php中关于mysqli和mysql区别的一些知识点整理

简介:这是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)

以上是一些��的介�,如有疏漏��也�迎大家�充。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值