PHP mysqli的prepare准备语句使用说明

mysqli对prepare的支持对于大访问量的网站是很有好处的,它极大地降低了系统开销,而且保证了创建查询的稳定性和安全性。prepare准备语句分为绑定参数和绑定结果,下面将会一一介绍! 

(1)绑定参数 
看下面php代码: 

<?php 
//创建连接 
$mysqli=new mysqli("localhost","root","","volunteer"); 
//检查连接是否被创建 
if (mysqli_connect_errno()) { 
printf("Connect failed: %s\n", mysqli_connect_error()); 
exit(); 
} 
/* 
* 创建一个准备查询语句: 
* ?是个通配符,可以用在任何有文字的数据 
* 相当于一个模板,也就是预备sql语句 
*/ 
if ($stmt = $mysqli->prepare("insert into `vol_msg`(mid,content) values(?,?)")){ 
/*第一个参数是绑定类型,"s"是指一个字符串,也可以是"i",指的是int。也可以是"db", 
* d代表双精度以及浮点类型,而b代表blob类型,第二个参数是变量 
*/ 
$stmt->bind_param("is",$id,$content); 
//给变量赋值 
$id = ""; 
$content = "这是插入的内容"; 
//执行准备语句 
$stmt->execute(); 
//显示插入的语句 
echo "Row inserted".$stmt->affected_rows; 
//下面还可以继续添加多条语句,不需要prepare预编译了 
//关闭数据库的链接 
$mysqli->close(); 
} 
?> 
以上php实例运行结果: 
Row inserted:1 


(2).绑定结果:绑定结果就是将你绑定的字段给php变量,以便必要时使用这些变量 
请看下面的php代码: 

<?php 
//创建连接 
$mysqli=new mysqli("localhost","root","","volunteer"); 
//设置mysqli编码 
mysqli_query($mysqli,"SET NAMES utf8"); 
//检查连接是否被创建 
if (mysqli_connect_errno()) { 
printf("Connect failed: %s\n", mysqli_connect_error()); 
exit(); 
} 
//创建准备语句 
if ($stmt = $mysqli->prepare("select mid,content from `vol_msg`")){ 
//执行查询 
$stmt->execute(); 
//为准备语句绑定实际变量 
$stmt->bind_result($id,$content); 
//显示绑定结果的变量 
while($stmt->fetch()){ 
echo "第".$id."条: ".$content."<br />"; 
} 
//关闭数据库的链接 
$mysqli->close(); 
} 
?> 

参考阅读:http://www.manongjc.com/article/1194.html

转载于:https://www.cnblogs.com/myhomepages/p/6010087.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值