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 相关文章推荐
PHP5 面向对象程序设计
Feb 13 PHP
PHP学习笔记之三 数据库基本操作
Jan 17 PHP
rrmdir php中递归删除目录及目录下的文件
May 15 PHP
把1316这个数表示成两个数的和,其中一个为13的倍数,另一个是11的倍数,求这两个数。
Jun 24 PHP
php保存二进制原始数据为图片的程序代码
Oct 14 PHP
php中base_convert()进制数字转换函数实例
Nov 20 PHP
php实现背景图上添加圆形logo图标的方法
Nov 17 PHP
php文件包含目录配置open_basedir的使用与性能详解
Apr 03 PHP
windows下的WAMP环境搭建图文教程(推荐)
Jul 27 PHP
安装docker和docker-compose实例详解
Jul 30 PHP
Thinkphp框架使用list_to_tree 实现无限级分类列出所有节点示例
Apr 04 PHP
PHP常用header头定义代码示例汇总
Aug 29 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计算排列组合的方法
2013/11/13 PHP
Yii框架调试心得--在页面输出执行sql语句
2014/12/25 PHP
php实现统计目录文件大小的函数
2015/12/25 PHP
深入理解PHP之OpCode原理详解
2016/06/01 PHP
Laravel框架实现的批量删除功能示例
2019/01/16 PHP
JavaScript延迟加载
2021/03/09 Javascript
jQuery DOM操作小结与实例
2010/01/07 Javascript
javascript smipleChart 简单图标类
2011/01/12 Javascript
使用JavaScript动态设置样式实现代码及演示动画
2013/01/25 Javascript
jQery使网页在显示器上居中显示适用于任何分辨率
2014/06/09 Javascript
JS实现文字向下滚动完整实例
2015/02/06 Javascript
浅谈NodeJS中require路径问题
2015/05/07 NodeJs
jQuery简单实现input文本框内灰色提示文本效果的方法
2015/12/02 Javascript
通过node-mysql搭建Windows+Node.js+MySQL环境的教程
2016/03/01 Javascript
详解Node.js模板引擎Jade入门
2018/01/19 Javascript
nuxt中使用路由守卫的方法步骤
2019/01/27 Javascript
JS中使用react-tooltip插件实现鼠标悬浮显示框
2019/05/15 Javascript
解决vue init webpack 下载依赖卡住不动的问题
2020/11/09 Javascript
Python字符串的encode与decode研究心得乱码问题解决方法
2009/03/23 Python
Python实现给文件添加内容及得到文件信息的方法
2015/05/28 Python
Python判断直线和矩形是否相交的方法
2015/07/14 Python
基于python实现微信模板消息
2015/12/21 Python
解决Matplotlib图表不能在Pycharm中显示的问题
2018/05/24 Python
Python数据类型之List列表实例详解
2019/05/08 Python
Python数学形态学实例分析
2019/09/06 Python
python实现图像拼接
2020/03/05 Python
Python Pivot table透视表使用方法解析
2020/09/11 Python
Pycharm操作Git及GitHub的步骤详解
2020/10/27 Python
Django用户认证系统如何实现自定义
2020/11/12 Python
Python 中的函数装饰器和闭包详解
2021/02/06 Python
Linux管理员面试题 Linux admin interview questions
2014/11/01 面试题
JSP&Servlet技术面试题
2015/05/21 面试题
一道Delphi上机题
2012/06/04 面试题
教师自我鉴定
2013/12/13 职场文书
企业宣传标语
2014/06/09 职场文书
2015年度考核个人工作总结
2015/10/24 职场文书