在通常情况下,使用PHP构建的应用系统都是搭配着MySQL数据库,很长时间以来,mysql扩展一直伴随着PHP与MySQL,并为二者之间的交互提供了通道。mysql扩展库提供的相关函数使PHP程序存取MySQL数据库变得很容易,但是,随着MySQL的发展,mysql扩展开始出现一些新问题,因为mysql扩展无法支持MySQL 4.1及其更高版本的新特性。
面对mysql扩展功能上的的不足,PHP的开发人员决定建立一种全新支持PHP 5的MySQL扩展程序,这就是mysqli扩展。
1 mysqli简介
mysqli扩展使得用户可以利用MySQL 4.1及其更高版本的新功能,与mysql扩展相比,mysqli扩展在以下方面有了明显的提高。
兼容性与维护性:mysqli扩展可以很容易地使用MySQL的新功能,所以mysqli拥有与MySQL更高的兼容性。即使MySQL的新版本又出现了更多功能,mysqli扩展也可以很容易的支持。
面向对象:mysqli扩展已封装到一个类中,从而可使用面向对象的方式编程。即使对面向对象不了解,mysqli扩展也提供了面向过程的编程方式来供用户选择。
速度和安全性:mysqli扩展执行的速度要比之前版本的mysql扩展快了很多。mysqli扩展支持MySQL新版本的密码杂凑(Password Hashes)和验证程序,更加提高了应用程序的安全性。
图23-24 使用query()方法的查询结果
对于删除记录(delete)、保存记录(insert)和修改记录(update)的操作,也是使用query()方法来执行的,下面是删除记录的例子:
<?php
$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脚本中的自定义变量绑定到结果集中的相应字段上,这些变量就代表着所查询的记录,绑定结果的示例代码如下:
<?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); //绑定结果
字符种类
|
代表的数据类型
|
I
|
integer
|
D
|
double
|
S
|
string
|
B
|
blob
|
参数types接受的字符的种类和绑定的变量需要一一对应。
var1:绑定的变量,其数量必须要与SQL语句中的参数数量保持一致。
绑定参数的示例代码如下:
<?php
$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();
?>
在一个脚本中还可以同时绑定参数和绑定结果,示例代码如下:
<?php
$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."<br>";
echo $number."<br>";
echo $name."<br>";
echo $age."<br>";
}
$result->close();
$mysqli->close();
?>
5 多个查询
mysqli扩展提供了能连续执行多个查询的multi_query()方法,该方法的语法格式如下:
bool mysqli_multi_query ( mysqli $link , string $query )
在执行多个查询时,除了最后一个查询语句,每个查询语句之间要用“;”分开。执行多个查询的示例代码如下:
代码23-33 光盘\codes\第23章\23.5\multi_query.php
$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)) { //执行多个查询
图23-25 执行多个查询
对于删除记录(delete)、保存记录(insert)和修改记录(update)的操作,也是使用query()方法来执行的,下面是删除记录的例子:
代码23-29 光盘\codes\第23章\23.5\querydelete.php
<?php
$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语句进行相应的修改即可。