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面向对象编程快速入门
Dec 14 PHP
phpMyAdmin 链接表的附加功能尚未激活的问题
Aug 01 PHP
php中将地址生成迅雷快车旋风链接的代码[测试通过]
Apr 20 PHP
JS与PHP向函数传递可变参数的区别实例代码
May 18 PHP
一个php短网址的生成代码(仿微博短网址)
May 07 PHP
php实现的日历程序
Jun 18 PHP
PHP基于文件存储实现缓存的方法
Jul 20 PHP
php opendir()列出目录下所有文件的实例代码
Oct 02 PHP
PHP-X系列教程之内置函数的使用示例
Oct 16 PHP
PHP实现将上传图片自动缩放到指定分辨率,并保持清晰度封装类示例
Jun 17 PHP
laravel model 两表联查示例
Oct 24 PHP
Laravel5.1 框架控制器基础用法实例分析
Jan 04 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
ASP知识讲座四
2006/10/09 PHP
PHP输出XML到页面的3种方法详解
2013/06/06 PHP
ThinkPHP之用户注册登录留言完整实例
2014/07/22 PHP
PHP实现仿Google分页效果的分页函数
2015/07/29 PHP
Extjs学习笔记之八 继承和事件基础
2010/01/08 Javascript
js操作textarea方法集合封装(兼容IE,firefox)
2011/02/22 Javascript
在IE浏览器中resize事件执行多次的解决方法
2011/07/12 Javascript
JS实现一键回顶功能示例代码
2013/10/28 Javascript
JS获取当前网址、主机地址项目根路径
2013/11/19 Javascript
js随机生成字母数字组合的字符串 随机动画数字
2015/09/02 Javascript
jQuery的ajax下载blob文件
2016/07/21 Javascript
tab栏切换原理
2017/03/22 Javascript
js 提取某()特殊字符串长度的实例
2017/12/06 Javascript
详解js跨域请求的两种方式,支持post请求
2018/05/05 Javascript
vue element项目引入icon图标的方法
2018/06/06 Javascript
微信小程序swiper左右扩展各显示一半代码实例
2019/12/05 Javascript
微信小程序单选框自定义赋值
2020/05/26 Javascript
vue基于better-scroll实现左右联动滑动页面
2020/06/30 Javascript
在vue中使用防抖函数组件操作
2020/07/26 Javascript
python操作xml文件示例
2014/04/07 Python
Windows下PyCharm安装图文教程
2018/08/27 Python
Python线程同步的实现代码
2018/10/03 Python
用Python读取几十万行文本数据
2018/12/24 Python
pandas对dataFrame中某一个列的数据进行处理的方法
2019/07/08 Python
python os.fork() 循环输出方法
2019/08/08 Python
python字典setdefault方法和get方法使用实例
2019/12/25 Python
解决Alexnet训练模型在每个epoch中准确率和loss都会一升一降问题
2020/06/17 Python
Python 没有main函数的原因
2020/07/10 Python
Python 实现微信自动回复的方法
2020/09/11 Python
一套比较完整的软件测试人员面试题
2012/05/13 面试题
英文自荐信格式
2013/11/28 职场文书
中华在我心中演讲稿
2014/09/13 职场文书
物业工程部经理岗位职责
2015/04/09 职场文书
SpringCloud Alibaba项目实战之nacos-server服务搭建过程
2021/06/21 Java/Android
Win7/8.1用户可以免费升级到Windows 11系统吗?
2021/11/21 数码科技
如何开启Apache,Nginx和IIS服务器的GZIP压缩功能
2022/04/29 Servers