首頁 後端開發 php教程 PHP5 mysqli 教程

PHP5 mysqli 教程

Jun 23, 2016 pm 01:30 PM

mysqli提供了面向对象和面向过程两种方式来与数据库交互,分别看一下这两种方式。

1.面向对象

在面向对象的方式中,mysqli被封装成一个类,它的构造方法如下:

__construct ([ string $host [, string $username [, string $passwd [, string $dbname

                 [, int $port [, string $socket ]]]]]] )       

在上述语法中涉及到的参数说明如下。

l        host:连接的服务器地址。

l        username:连接数据库的用户名,默认值是服务器进程所有者的用户名。

l        passwd:连接数据库的密码,默认值为空。

l        dbname:连接的数据库名称。

l        port:TCP端口号。

l        socket:UNIX域socket。

要建立与MySQL的连接可以通过其构造方法实例化mysqli类,例如下面的代码:

$db_host="localhost";                                      //连接的服务器地址

$db_user="root";                                            //连接数据库的用户名

$db_psw="root";                                            //连接数据库的密码

$db_name="sunyang";                                      //连接的数据库名称

$mysqli=new mysqli($db_host,$db_user,$db_psw,$db_name);

?>

mysqli还提供了一个连接MySQL的成员方法connect()。当实例化构造方法为空的mysqli类时,用mysqli对象调用connect()方法同样可连接MySQL,例如,下面的代码:

$db_host="localhost";                                      //连接的服务器地址

$db_user="root";                                            //连接数据库的用户名

$db_psw="root";                                            //连接数据库的密码

$db_name="sunyang";                                      //连接的数据库名称

$mysqli=new mysqli();

$mysqli->connect($db_host,$db_user,$db_psw,$db_name);

?>

关闭与MySQL服务器的连接通过mysqli对象调用close()方法即可,例如:

$mysqli->close();

 

2.面向过程

 

在面向过程的方式中,mysqli扩展提供了函数mysqli_connect()与MySQL建立连接,该函数的语法格式如下:

mysqli mysqli_connect ([ string $host [, string $username [, string $passwd

                                 [, string $dbname [, int $port [, string $socket ]]]]]] )

mysqli_connect()函数的用法与mysql扩展中的mysql_connect()函数用法十分相似,下面是mysqli_connect()函数的用法示例:

 

$connection = mysqli_connect("localhost","root","root","sunyang");

if ( $connection ) {

        echo "数据库连接成功";

}else {

        echo "数据库连接失败";

}

?>

 

关闭与MySQL服务器的连接使用mysqli_close()函数,例如:

mysqli_close();

 

3  使用mysqli存取数据

 

使用mysqli存取数据也包括面向对象和面向过程两种方式,在本节我们只讨论如何使用面向对象的方式来与MySQL交互,关于mysqli扩展中使用面向过程方式这里就不再详细介绍了,有兴趣的读者可参考官方文档来获取相关的资料。

在mysqli中,执行查询使用query()方法,该方法的语法格式如下:

mixed query ( string $query [, int $resultmode ] )

在上述语法中涉及到的参数说明如下。

l        query:向服务器发送的SQL语句。

l        resultmode:该参数接受两个值,一个是MYSQLI_STORE_RESULT,表示结果作为缓冲集合返回;另一个是MYSQLI_USE_RESULT,表示结果作为非缓冲集合返回。

下面是使用query()方法执行查询的例子:

$mysqli=new mysqli("localhost","root","root","sunyang");    //实例化mysqli

$query="select * from employee";

$result=$mysqli->query($query);

if ($result) {

        if($result->num_rows>0){                                         //判断结果集中行的数目是否大于0

                while($row =$result->fetch_array() ){                     //循环输出结果集中的记录

                        echo ($row[0])."
";

                        echo ($row[1])."
";

                        echo ($row[2])."
";

                        echo ($row[3])."
";

                        echo "


";

                }

        }

}else {

        echo "查询失败";

}

$result->free();

$mysqli->close();

?>

在上面代码中,num_rows为结果集的一个属性,返回结果集中行的数目。方法fetch_array()将结果集中的记录放入一个数组中并将其返回。最后使用free()方法将结果集中的内存释放,使用close()方法将数据库连接关闭。

 

对于删除记录(delete)、保存记录(insert)和修改记录(update)的操作,也是使用query()方法来执行的,下面是删除记录的例子:

$mysqli=new mysqli("localhost","root","root","sunyang");            //实例化mysqli

$query="delete from employee where emp_id=2";

$result=$mysqli->query($query);

if ($result){

        echo "删除操作执行成功";

}else {

        echo "删除操作执行失败";

}

$mysqli->close();

?>

保存记录(insert)、修改记录(update)的操作与删除记录(delete)的操作类似,将SQL语句进行相应的修改即可。

 

4  预准备语句

 

使用预准备语句可提高重复使用语句的性能,在PHP中,使用prepare()方法来进行预准备语句查询,使用execute()方法来执行预准备语句。PHP有两种预准备语句:一种是绑定结果,另一种是绑定参数。

 

(1).绑定结果

 

所谓绑定结果就是把PHP脚本中的自定义变量绑定到结果集中的相应字段上,这些变量就代表着所查询的记录,绑定结果的示例代码如下:

$mysqli=new mysqli("localhost","root","root","sunyang");    //实例化mysqli

$query="select * from employee";

$result=$mysqli->prepare($query);                                //进行预准备语句查询

$result->execute();                                                  //执行预准备语句

$result->bind_result($id,$number,$name,$age);                 //绑定结果

while ($result->fetch()) {

        echo $id;

        echo $number;

        echo $name;

        echo $age;

}

$result->close();                                                     //关闭预准备语句

$mysqli->close();                                                   //关闭连接

?>

在绑定结果的时候,脚本中的变量要与结果集中的字段一一对应,绑定完以后,通过fetch()方法将绑定在结果集中的变量一一取出来,最后将预准备语句和数据库连接分别关闭。

 

(2).绑定参数

 

所谓绑定参数就是把PHP脚本中的自定义变量绑定到SQL语句中的参数(参数使用 “?”代替)上,绑定参数使用bind_param()方法,该方法的语法格式如下:

bool bind_param ( string $types , mixed &$var1 [, mixed &$... ] )

在上述语法中涉及到的参数说明如下。

l        types:绑定的变量的数据类型,它接受的字符种类包括4个,如表所示。

字符种类

代表的数据类型

I

integer

D

double

S

string

B

blob

参数types接受的字符的种类和绑定的变量需要一一对应。

 

l        var1:绑定的变量,其数量必须要与SQL语句中的参数数量保持一致。

绑定参数的示例代码如下:

$mysqli=new mysqli("localhost","root","root","sunyang");            //实例化mysqli

$query="insert into employee (emp_number,emp_name,emp_age) values (?,?,?)";

$result=$mysqli->prepare($query);

$result->bind_param("ssi",$number,$name,$age);                       //绑定参数

$number='sy0807';

$name='employee7';

$age=20;

$result->execute();                                                          //执行预准备语句

$result->close();

$mysqli->close();

?>

在一个脚本中还可以同时绑定参数和绑定结果,示例代码如下:

$mysqli=new mysqli("localhost","root","root","sunyang");    //实例化mysqli

$query="select * from employee where emp_id

$result=$mysqli->prepare($query);

$result->bind_param("i",$emp_id);                                //绑定参数

$emp_id=4;

$result->execute();

$result->bind_result($id,$number,$name,$age);                 //绑定结果

while ($result->fetch()) {

        echo $id."
";

        echo $number."
";

        echo $name."
";

        echo $age."
";

}

$result->close();

$mysqli->close();

?>

5  多个查询

 

mysqli扩展提供了能连续执行多个查询的multi_query()方法,该方法的语法格式如下:

bool mysqli_multi_query ( mysqli $link , string $query )

在执行多个查询时,除了最后一个查询语句,每个查询语句之间要用“;”分开。执行多个查询的示例代码如下:

$mysqli=new mysqli("localhost","root","root","sunyang");            //实例化mysqli

$query = "select emp_name from employee ;";

$query .= "select dep_name from depment ";

if ($mysqli->multi_query($query)) {                                      //执行多个查询

        do {

                if ($result = $mysqli->store_result()) {

                        while ($row = $result->fetch_row()) {

                                echo $row[0];

                                echo "
";

                        }

                        $result->close();

                }

                if ($mysqli->more_results()) {

                        echo ("-----------------
");                 //连个查询之间的分割线

                }

        } while ($mysqli->next_result());

}

$mysqli->close();//关闭连接

?>

在上述代码中,store_result()方法用于获得一个缓冲结果集; fetch_row()方法的作用类似于fetch_array()方法;more_results()方法用于从一个多查询中检查是否还有更多的查询结果;next_result()方法用于从一个多查询中准备下一个查询结果。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

會話如何劫持工作,如何在PHP中減輕它? 會話如何劫持工作,如何在PHP中減輕它? Apr 06, 2025 am 12:02 AM

會話劫持可以通過以下步驟實現:1.獲取會話ID,2.使用會話ID,3.保持會話活躍。在PHP中防範會話劫持的方法包括:1.使用session_regenerate_id()函數重新生成會話ID,2.通過數據庫存儲會話數據,3.確保所有會話數據通過HTTPS傳輸。

描述紮實的原則及其如何應用於PHP的開發。 描述紮實的原則及其如何應用於PHP的開發。 Apr 03, 2025 am 12:04 AM

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

在PHPStorm中如何進行CLI模式的調試? 在PHPStorm中如何進行CLI模式的調試? Apr 01, 2025 pm 02:57 PM

在PHPStorm中如何進行CLI模式的調試?在使用PHPStorm進行開發時,有時我們需要在命令行界面(CLI)模式下調試PHP�...

PHP 8.1中的枚舉(枚舉)是什麼? PHP 8.1中的枚舉(枚舉)是什麼? Apr 03, 2025 am 12:05 AM

PHP8.1中的枚舉功能通過定義命名常量增強了代碼的清晰度和類型安全性。 1)枚舉可以是整數、字符串或對象,提高了代碼可讀性和類型安全性。 2)枚舉基於類,支持面向對象特性,如遍歷和反射。 3)枚舉可用於比較和賦值,確保類型安全。 4)枚舉支持添加方法,實現複雜邏輯。 5)嚴格類型檢查和錯誤處理可避免常見錯誤。 6)枚舉減少魔法值,提升可維護性,但需注意性能優化。

如何在系統重啟後自動設置unixsocket的權限? 如何在系統重啟後自動設置unixsocket的權限? Mar 31, 2025 pm 11:54 PM

如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...

解釋PHP中的晚期靜態綁定(靜態::)。 解釋PHP中的晚期靜態綁定(靜態::)。 Apr 03, 2025 am 12:04 AM

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

See all articles