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 相关文章推荐
Dedecms常用函数解析
Feb 01 PHP
应用开发中涉及到的css和php笔记分享
Aug 02 PHP
php无限遍历文件夹示例分享
Mar 04 PHP
php+ajax实时刷新简单实例
Feb 25 PHP
linux下php上传文件注意事项
Jun 11 PHP
PHP获取当前执行php文件名的代码
Mar 02 PHP
PHP用户管理中常用接口调用实例及解析(含源码)
Mar 09 PHP
PHP实现的数独求解问题示例
Apr 18 PHP
PHP文件系统管理(实例讲解)
Sep 19 PHP
PHP+AJAX 投票器功能
Nov 11 PHP
PHP中使用mpdf 导出PDF文件的实现方法
Oct 22 PHP
php设计模式之观察者模式定义与用法经典示例
Sep 19 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
一些星际专用术语解释
2020/03/04 星际争霸
DOTA2 1月28日更新:监管系统降临刀塔世界
2021/01/28 DOTA
php通用防注入程序 推荐
2011/02/26 PHP
windows环境下php配置memcache的具体操作步骤
2013/06/09 PHP
PHP生成sitemap.xml地图函数
2013/11/13 PHP
PHP中ini_set与ini_get用法实例
2014/11/04 PHP
php使用PDO执行SQL语句的方法分析
2017/02/16 PHP
Yii2实现ActiveForm ajax提交
2017/05/26 PHP
Javascript YUI 读码日记之 YAHOO.util.Dom - Part.3
2008/03/22 Javascript
用jquery实现等比例缩放图片效果插件
2010/07/24 Javascript
js获取网页可见区域、正文以及屏幕分辨率的高度
2014/05/15 Javascript
JavaScript中神奇的call()方法
2015/03/12 Javascript
javascript实现的多个层切换效果通用函数实例
2015/07/06 Javascript
JavaScript脚本库编写的方法
2015/12/09 Javascript
jQuery实现模糊搜索功能的方法分析
2018/06/29 jQuery
Vue.set 全局操作简单示例
2019/09/19 Javascript
Vue-axios-post数据后端接不到问题解决
2020/01/09 Javascript
JavaScript 如何计算文本的行数的实现
2020/09/14 Javascript
H5 js点击按钮复制文本到粘贴板
2020/11/19 Javascript
python抓取京东价格分析京东商品价格走势
2014/01/09 Python
解读Python中degrees()方法的使用
2015/05/18 Python
python创建列表并给列表赋初始值的方法
2015/07/28 Python
Python类属性的延迟计算
2016/10/22 Python
Python实现模拟浏览器请求及会话保持操作示例
2018/07/30 Python
pandas.DataFrame删除/选取含有特定数值的行或列实例
2018/11/07 Python
在Python中COM口的调用方法
2019/07/03 Python
python实现企业微信定时发送文本消息的示例代码
2020/11/24 Python
德国拖鞋网站:German Slippers
2019/11/08 全球购物
c++工程师面试问题
2013/08/04 面试题
干部培训自我鉴定
2014/01/22 职场文书
十八届三中全会学习方案
2014/02/16 职场文书
管理建议书范文
2014/05/13 职场文书
春节慰问简报
2015/07/21 职场文书
八年级英语教学反思
2016/02/15 职场文书
导游词创作书写原则以及开场白技巧怎么学?
2019/09/25 职场文书
德劲DE1102数字调谐收音机机评
2022/04/07 无线电