codetc - 网站开发技术 首页 后端 PHP 查看内容

PHP5中使用mysqli的prepare操作数据库

2014-12-27 02:03| 发布者: CODETC| 查看: 5171| 评论: 0

PHP5.0后我们可以使用mysqli,mysqli对prepare的支持对于大访问量的网站是很有好处的,特别是事务的支持,在大查询量的时候将极大地降低了系统开销,而且保证了创建查询的稳定性和安全性,能有效地防止SQL注入攻击。prepare准备语句分为绑定参数和绑定结果两种。


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

<?php 
//创建连接 
$mysqli=new mysqli("localhost","root","","123456"); 
//检查连接是否被创建 
if (mysqli_connect_errno()) { 
	printf("Connect failed: %s\n", mysqli_connect_error()); 
	exit(); 
}
/** 
 * 创建一个准备查询语句: 
 * ?是个通配符,可以用在任何有文字的数据 
 * 相当于一个模板,也就是预备sql语句 
 */ 
if ($stmt = $mysqli->prepare("insert into `codetc_msg`(mid,content) values(?,?)")){ 
	/**
	 * 第一个参数是绑定类型,"is"是指上面SQL语句中第一个?参数是int类型,第二个?参数是string类型 
	 * 其中i指int,s指string, 除了i、s之外还有d代表双精度浮点型,b代表blod类型等
	 */ 
	$stmt->bind_param("is",$id,$content); 
	//给变量赋值 
	$id = 1; 
	$content = "这是插入的内容"; 
	//执行准备语句 
	$stmt->execute(); 
	//显示插入的影响行数
	echo "Row inserted".$stmt->affected_rows; 
	//关闭数据库的链接 
	$mysqli->close(); 
} 
?> 

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

 
<?php 
//创建连接 
$mysqli=new mysqli("localhost","root","","123456"); 
//设置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 `codetc_msg`")){ 
	//执行查询 
	$stmt->execute(); 
	//为准备语句绑定实际变量 
	$stmt->bind_result($id,$content); 
	//显示绑定结果的变量 
	while($stmt->fetch()){ 
		echo "第".$id."条: ".$content."<br>"; 
	} 
	//关闭数据库的链接 
	$mysqli->close(); 
} 
?>

文章来源 CODETC,欢迎分享,转载请注明地址: http://www.codetc.com/article-106-1.html

最新评论

 作为游客发表评论,请输入您的昵称

返回顶部