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 相关文章推荐
php中文件上传的安全问题
Oct 09 PHP
随机广告显示(PHP函数)
Oct 09 PHP
用PHP读取和编写XML DOM的实现代码
Feb 03 PHP
php和mysql中uft-8中文编码乱码的几种解决办法
Apr 19 PHP
php中explode与split的区别介绍
Oct 03 PHP
php函数array_merge用法一例(合并同类数组)
Feb 03 PHP
php面向对象中的魔术方法中文说明
Mar 04 PHP
体育彩票排列三组选三算法分享
Mar 07 PHP
详解WordPress中提醒安装插件以及隐藏插件的功能实现
Dec 25 PHP
Yii+upload实现AJAX上传图片的方法
Jul 13 PHP
Laravel中七个非常有用但很少人知道的Carbon方法
Sep 21 PHP
Thinkphp5.0 框架使用模型Model添加、更新、删除数据操作详解
Oct 11 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
收听困难?教您超简便短波广播抗干扰方法!
2021/03/01 无线电
解析使用ThinkPHP应该掌握的调试手段
2013/06/20 PHP
PHP getallheaders无法获取自定义头(headers)的问题
2016/03/23 PHP
PHP正则表达式匹配替换与分割功能实例浅析
2017/02/04 PHP
图片之间的切换
2006/06/26 Javascript
JavaScript 开发中规范性的一点感想
2009/06/23 Javascript
根据IP的地址,区分不同的地区,查看不同的网站页面的js代码
2013/02/26 Javascript
JS 如何获取radio选中后的值及不选择取radio的值
2013/10/28 Javascript
一个JavaScript函数把URL参数解析成Json对象
2014/09/24 Javascript
js style.display=block显示布局错乱问题的解决方法
2016/09/21 Javascript
AngularJS 中使用Swiper制作滚动图不能滑动的解决方法
2016/11/15 Javascript
Three.js中网格对象MESH的属性与方法详解
2017/09/27 Javascript
微信小程序实现图片上传放大预览删除代码
2020/06/28 Javascript
详解vue使用vue-layer-mobile组件实现toast,loading效果
2018/08/31 Javascript
简单了解JavaScript异步
2019/05/23 Javascript
js正则匹配多个全部数据问题
2019/12/20 Javascript
如何在vue中使用jointjs过程解析
2020/05/29 Javascript
vue使用自定义事件的表单输入组件用法详解【日期组件与货币组件】
2020/06/01 Javascript
[00:32]2018DOTA2亚洲邀请赛OpTic出场
2018/04/03 DOTA
Python中的高级数据结构详解
2015/03/27 Python
Python GUI布局尺寸适配方法
2018/10/11 Python
Python安装selenium包详细过程
2019/07/23 Python
解决python 文本过滤和清理问题
2019/08/28 Python
Python3.8对可迭代解包的改进及用法详解
2019/10/15 Python
Tkinter中复选菜单是否被选中的判断与设置方式
2020/03/04 Python
HTML5画渐变背景图片并自动下载实现步骤
2013/11/18 HTML / CSS
Maje德国官网:法国女性成衣品牌
2017/02/10 全球购物
瑞士设计师家具和家居饰品网上商店:Bruno Wickart
2019/03/18 全球购物
安德玛加拿大官网:Under Armour加拿大
2019/10/02 全球购物
企业总经理岗位职责
2014/02/13 职场文书
人事专员的职责
2014/02/26 职场文书
学习普通话的体会
2014/11/07 职场文书
幼师中班个人总结
2015/02/12 职场文书
2015财务年度工作总结范文
2015/05/04 职场文书
2019年关于小学生课外阅读情况的分析报告
2019/12/02 职场文书
python模块与C和C++动态库相互调用实现过程示例
2021/11/02 Python