时间:2021-05-26
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(); } ?>总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
PHP数据库操作中,mysqli相对于mysql有很大的优势,建议大家使用;之前我们有介绍过如何在PHP5中使用mysqli的prepare操作数据库,使用my
本文实例讲述了PHP入门教程之使用Mysqli操作数据库的方法。分享给大家供大家参考,具体如下:Demo1.phpconnect();$_mysqli->con
使用语言操作数据库是重中之重,如果一门语言你不懂得如何操作数据库,那么你还是没有学会这门语言。PHP操作数据库的方法并不难同时php的值还可以与JavaScri
本文实例讲述了PHP使用PDO操作数据库的乱码问题解决方法。分享给大家供大家参考,具体如下:当使用PDO连接操作数据库的时候,有时会出现:保存在数据库中的汉字为
前言本文是对SpringBoot使用JdbcTemplate操作数据库的一个介绍,提供一个小的Demo供大家参考。操作数据库的方式有很多,本文介绍使用Sprin