Home > php教程 > php手册 > 深入分析mysql与mysqli的不同之处

深入分析mysql与mysqli的不同之处

WBOY
Release: 2016-05-25 16:38:32
Original
1425 people have browsed it

php中mysql与mysqli对于数据库的连接操作是有所区别的,从最基于的区别来看是ysqli 连接是永久连接,而mysql是非永久连接了,下面我们来深入的分析它们两的区别.

首先,两个函数都是用来处理数据库操作的,mysqli 连接是永久连接,而mysql是非永久连接.

mysql连接每当第二次使用时,都会重新打开一个新的进程,而mysqli则只使用同一个进程,可以很大程度的减轻服务器端压力.

其次,mysqli封装了诸如事务等一些高级操作,同时封装了数据库操作过程中的很多可用的方法.

具体查看 http://cn.php.net/mysqli

在实际使用中,较多使用到mysqli的事务.

PHP代码示例如下:

<?php
$mysqli = new mysqli(&#39;localhost&#39;, &#39;root&#39;, &#39;&#39;, &#39;DB_Lib2Test&#39;);
$mysqli->autocommit(false); //开始事物
$mysqli->query($sql1);
$mysqli->query($sql2);
if (!$mysqli->errno) {
    $mysqli->commit();
    echo &#39;ok&#39;;
} else {
    echo &#39;err&#39;;
    $mysqli->rollback();
}
?>
Copy after login

第二部分,php中关于mysqli和mysql区别

php-mysql 是 php 操作 mysql 资料库最原始的 extension ,php-mysqli 的 i 代表 improvement ,提更了相对进阶的功能,就 extension 而言,本身也增加了安全性。而 pdo (php data object) 则是提供了一个 abstraction layer 来操作资料库。

PHP实例代码如下:

<?php 
mysql_connect($db_host, $db_user, $db_password); 
mysql_select_db($dn_name); 
$result = mysql_query("SELECT `name` FROM `users` WHERE `location` = &#39;$location&#39;"); 
while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) 
{
echo $row[&#39;name&#39;]; 
} 
mysql_free_result($result);
Copy after login

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

PHP实例代码如下:

<?php 
$query = sprintf("SELECT * FROM users WHERE user=&#39;%s&#39; AND password=&#39;%s&#39;", 
mysql_real_escape_string($user), 
mysql_real_escape_string($password)); 
mysql_query($query);
Copy after login

在 php-mysqli 中有了不少进步,除了透过 bind column 来解决上述问题,而且也多援 transaction, multi query,并且同时提供了 object oriented style (下面这段 php-mysqli 范例的写法) 和 procedural style (上面 php-mysql 范例的写法)两种写法…等等.

PHP实例代码如下:

<?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(&#39;dsss&#39;, $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();
Copy after login

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

于是 pdo 就出现了(备注:目前 ubuntu 和 debian 来说,pdo 并没有直接的套件可以安装,而是必须透过 pecl 安装)。

PHP实例代码如下:

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 安装装好后,就可以透过以下方式来操作资料库,代码示例:

<?php 
$dsn = "mysql:host=$db_host;dbname=$db_name"; 
$dbh = new PDO($dsn, $db_user, $db_password); 
$sql = "SELECT `name`, `location` FROM `users` WHERE `location` = ? , `name` = ?"; 
$sth = $dbh->prepare($sql); 
$sth->execute(array($location, $name)); 
$result = $sth->fetch(PDO::FETCH_OBJ); 
echo $result->name . $result->location; 
$dbh = NULL;
Copy after login

乍看之下,pdo 的程式码好像也没有比较短,那到底好处是什麽呢?

1. pdo 连接资料库时透过 connection string 来决定连接何种资料库。

2. pdo 可以透过 pdo::setattribute 来决定连线时的设定,像是 persistent connection, 回传错误的方式(exception, e_warning, null)。甚至是回传栏位名称的大小写…等等。

3. 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 来写是,代码示例:

<?php 
$sql = "INSERT INTO `users` (id, name, gender, location) VALUES(?, ?, ?, ?)"; 
$sth = $dbh->prepare($sql); 
$sth->execute(array(1, &#39;roga&#39;, &#39;male&#39;, &#39;tpe&#39;));
Copy after login

但以 ActiveRecord 来说的话,则是,代码示例:

<?php 
$user = new User(); 
$user->id = 1; 
$user->name = &#39;roga&#39;; 
$user->gender = &#39;male&#39;; 
$user->location = &#39;tpe&#39;; 
$user->save();
Copy after login

后者在语法上是不是简洁很多呢,而且也大幅降低对 SQL 语言的依赖性!(不同资料库对 SQL 实作的问题可参考 Comparison of different SQL implementations)

以上是一些简单的介绍,如有疏漏谬误也欢迎大家补充。

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是一个允许以对象的方式或者过程操作数据库的,它的使用方式也很容易。这里就几个常见的操作和 mysql.dll做一个对比。

1、mysql.dll(可以理解为函数式的方式):

$conn = mysql_connect(&#39;localhost&#39;, &#39;user&#39;, &#39;password&#39;); //连接mysql数据库 
mysql_select_db(&#39;data_base&#39;); //选择数据库 
 
$result = mysql_query(&#39;select * from data_base&#39;);//这里有第二个可选参数,指定打开的连接 
$row = mysql_fetch_row( $result ) ) //为了简单,这里只取一行数据 
echo $row[0]; //输出第一个字段的值
Copy after login

mysqli也有过程式的方式,只不过开始贯以mysqli的前缀,其他都差不多,如果mysqli以过程式的方式操作的话,有些函数必须指定资源,比如说 mysqli_query(资源标识,SQL语句),并且资源标识的参数是放在前面的,而 mysql_query(SQL语句,'可选')的资源标识是放在后面的,并且可以不指定,它默认是上一个打开的连接或资源.

2、mysqli.dll(对象方式),代码示例:

$conn = new mysqli(&#39;localhost&#39;, &#39;user&#39;, &#39;password&#39;,&#39;data_base&#39;); 
//这里的连接是new出来的,最后一个参数是直接指定数据库,不用mysql_select_db()了 
//也可以构造时候不指定,然后 $conn -> select_db(&#39;data_base&#39;) 
$result = $conn -> query( &#39;select * from data_base&#39; ); 
$row = $result -> fetch_row(); //取一行数据 
echo row[0]; //输出第一个字段的值
Copy after login

二、mysql_fetch_row(),mysql_fetch_array()

这两个函数,返回的都是一个数组,区别就是第一个函数返回的数组是只包含值,我们只能$row[0],$row[1],这样以数组下标来读取数据,而mysql_fetch_array()返回的数组既包含第一种,也包含键值对的形式,可以这样读取数据,假如数据库的字段是 username,passwd,代码示例:

$row['username'], $row['passwd']

而且,如果用($row as $kay => $value)来操作的话,还以直接取得数据库的字段名称.

更主要的是mysqli是php5提供的新函数库,(i)表示改进,其执行速度更快.


永久地址:

转载随意~请带上教程地址吧^^

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Recommendations
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template