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


Posted in PHP onMarch 18, 2019

php5中有了mysqli对prepare的支持,对于大访问量的网站是很有好处的,极大地降低了系统开销,而且保证了创建查询的稳定性和安全性。

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。如果你想了解更多相关内容请查看下面相关链接

PHP 相关文章推荐
Windows下的PHP5.0安装配制详解
Sep 05 PHP
PHP的FTP学习(二)
Oct 09 PHP
php 远程关机操作的代码
Dec 05 PHP
phpMyAdmin 安装及问题总结
May 28 PHP
写出高质量的PHP程序
Feb 04 PHP
php指定函数参数默认值示例代码
Dec 04 PHP
美图秀秀web开放平台--PHP流式上传和表单上传示例分享
Jun 22 PHP
php数组键值用法实例分析
Feb 27 PHP
PHP+原生态ajax实现的省市联动功能详解
Aug 15 PHP
JSON PHP中,Json字符串反序列化成对象/数组的方法
May 31 PHP
php获得刚插入数据的id 的几种方法总结
May 31 PHP
PHP的PDO连接讲解
Jan 24 PHP
php+ajax 文件上传代码实例
Mar 18 #PHP
PHP中单例模式的使用场景与使用方法讲解
Mar 18 #PHP
详解php中curl返回false的解决办法
Mar 18 #PHP
浅谈PHP SHA1withRSA加密生成签名及验签
Mar 18 #PHP
PHP自动生成缩略图函数的源码示例
Mar 18 #PHP
PHP添加文字水印或图片水印的水印类完整源代码与使用示例
Mar 18 #PHP
PHP实现对数字分隔加千分号的方法
Mar 18 #PHP
You might like
聊天室php&amp;mysql(三)
2006/10/09 PHP
探讨fckeditor在Php中的配置详解
2013/06/08 PHP
destoon公司主页模板风格的添加方法
2014/06/20 PHP
全面解析PHP验证码的实现原理 附php验证码小案例
2016/08/17 PHP
利用Homestead快速运行一个Laravel项目的方法详解
2017/11/14 PHP
Gambit vs ForZe BO3 第二场 2.13
2021/03/10 DOTA
jquery及原生js获取select下拉框选中的值示例
2013/10/25 Javascript
javascript操作css属性
2013/12/30 Javascript
jquery遍历checkbox介绍
2014/02/21 Javascript
显示今天的日期js代码(阳历和农历)
2014/09/30 Javascript
js实现数组转换成json
2015/06/26 Javascript
关于JavaScript的变量的数据类型的判断方法
2015/08/14 Javascript
利用百度地图API获取当前位置信息的实例
2017/11/06 Javascript
spring+angular实现导出excel的实现代码
2019/02/27 Javascript
Javascript实现html转pdf高清版(提高分辨率)
2020/02/19 Javascript
[55:45]DOTA2上海特级锦标赛D组败者赛 Liquid VS COL第一局
2016/02/28 DOTA
python翻译软件实现代码(使用google api完成)
2013/11/26 Python
python实现调用其他python脚本的方法
2014/10/05 Python
Python3通过Luhn算法快速验证信用卡卡号的方法
2015/05/14 Python
解决Python运行文件出现out of memory框的问题
2018/12/03 Python
Python 类的魔法属性用法实例分析
2019/11/21 Python
解决Tensorflow 使用时cpu编译不支持警告的问题
2020/02/03 Python
解决python调用自己文件函数/执行函数找不到包问题
2020/06/01 Python
python 写一个性能测试工具(一)
2020/10/24 Python
使用python画出逻辑斯蒂映射(logistic map)中的分叉图案例
2020/12/11 Python
CSS3之背景尺寸Background-size使用介绍
2013/10/14 HTML / CSS
美国领先的户外服装与装备用品店:Moosejaw
2016/08/25 全球购物
荷兰的时尚市场:To Be Dressed
2019/05/06 全球购物
GetYourGuide台湾:预订旅游活动、景点和旅游项目
2019/06/10 全球购物
俄罗斯儿童和青少年服装、鞋子及配件的在线商店:Orby
2020/02/20 全球购物
项目考察欢迎辞
2014/01/17 职场文书
综合实践教学反思
2014/01/31 职场文书
计算机考试作弊检讨书1000字
2015/01/01 职场文书
学校计划生育责任书
2015/05/09 职场文书
无故旷工检讨书
2015/08/15 职场文书
JavaScript parseInt0.0000005打印5原理解析
2022/07/23 Javascript