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 相关文章推荐
输出控制类
Oct 09 PHP
社区(php&amp;&amp;mysql)二
Oct 09 PHP
常用的php对象类型判断
Aug 27 PHP
PHP中去除换行解决办法小结(PHP_EOL)
Nov 27 PHP
LotusPhp笔记之:Cookie组件的使用详解
May 06 PHP
PHP 利用Mail_MimeDecode类提取邮件信息示例
Jan 26 PHP
php通过ajax实现双击table修改内容
Apr 28 PHP
PHP程序员基本要求和必备技能
May 09 PHP
php上传大文件失败的原因及应对策略
Oct 20 PHP
PHP判断FORM表单或URL参数来的数据是否为整数的方法
Mar 25 PHP
php处理多图上传压缩代码功能
Jun 13 PHP
浅谈laravel数据库查询返回的数据形式
Oct 21 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中的时间处理
2006/10/09 PHP
php empty函数判断mysql表单是否为空
2010/04/12 PHP
php禁止直接从浏览器输入地址访问.php文件的方法
2014/11/04 PHP
php实现xml与json之间的相互转换功能实例
2016/07/07 PHP
PHP code 验证码生成类定义和简单使用示例
2020/05/27 PHP
JavaScript.Encode手动解码技巧
2010/07/14 Javascript
JQuery 选择器、过滤器介绍
2011/02/14 Javascript
NodeJS制作爬虫全过程
2014/12/22 NodeJs
浅谈JS正则表达式的RegExp对象和括号的使用
2016/07/28 Javascript
js事件冒泡与事件捕获详解
2017/02/20 Javascript
Vue父子模版传值及组件传值的三种方法
2017/11/27 Javascript
React Native自定义控件底部抽屉菜单的示例
2018/02/08 Javascript
详解微信小程序之scroll-view的flex布局问题
2019/01/16 Javascript
js中null与空字符串&quot;&quot;的区别讲解
2019/01/17 Javascript
通过vue写一个瀑布流插件代码实例
2019/09/07 Javascript
CountUp.js实现数字滚动增值效果
2019/10/17 Javascript
python 线程的暂停, 恢复, 退出详解及实例
2016/12/06 Python
用python实现简单EXCEL数据统计的实例
2017/01/24 Python
python实现批量处理将图片粘贴到另一张图片上并保存
2019/12/12 Python
PyCharm2019.3永久激活破解详细图文教程,亲测可用(不定期更新)
2020/10/29 Python
可能这些是你想要的H5软键盘兼容方案(小结)
2019/04/23 HTML / CSS
New Balance天猫官方旗舰店:始于1906年,百年慢跑品牌
2017/11/15 全球购物
什么是虚拟内存?虚拟内存有什么优势?
2012/02/19 面试题
《日月潭》教学反思
2014/02/28 职场文书
《三亚落日》教学反思
2014/04/26 职场文书
合同意向书范本
2014/07/30 职场文书
庆祝教师节标语
2014/10/09 职场文书
2014年远程教育工作总结
2014/12/09 职场文书
2015年消防工作总结
2015/04/24 职场文书
爱国影片观后感
2015/06/18 职场文书
认识实习感想
2015/08/10 职场文书
新教师教学工作总结
2015/08/12 职场文书
导游词之苏州寒山寺
2019/12/05 职场文书
python 机器学习的标准化、归一化、正则化、离散化和白化
2021/04/16 Python
ORACLE数据库应用开发的三十个注意事项
2021/06/07 Oracle
MySQL创建管理子分区
2022/04/13 MySQL