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

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();
}
?>

第二部分,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);

这种方式不能 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);

在 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();

但看到这边又发现了一些缺点,例如得 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;

乍看之下,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;));

但以 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();

后者在语法上是不是简洁很多呢,而且也大幅降低对 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]; //输出第一个字段的值

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]; //输出第一个字段的值

二、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)表示改进,其执行速度更快.


永久地址:

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

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기