对PHP中的prepare()方法的解析

对PHP中的prepare()方法的解析,第1张

概述对PHP中的prepare()方法解析

每次发送查询语句给MysqL服务时,都必须解析该查询的语法,确保结构正确并能够执行。这是这个过程中必要的步骤,但也确实带来了一些开销。做一次是必要的,但是如果反复地执行相同的查询,批量插入多行时只改变列值,准备语句会在服务器上缓存查询的语法和执行过程,而只在服务器和客户端之间传输有变化的列值,以此来消除这些额外的开销。

首先我们来看一下PDO::prepare的语法:

public PDO::prepare ( string $statement   , array $driver_options = array()   ) : PDOStatement

$statement:必须是对目标数据库服务器有效的 sql 语句模板。

$driver_options:数组包含一个或多个 key=>value 键值对,为返回的 PDOStatement 对象设置属性

返回值如果数据库服务器完成准备了语句,返回PDOStatement 对象。如果数据库服务器无法准备语句,PDO::prepare() 返回 false 或抛出PDOException (取决于 错误处理器)。

代码实例:

1.连接数据库

<?PHP$servername="localhost";$username="root";$password="root123456";$dbname="my_database";$pdo=new PDO("MysqL:host=$servername;dbname=$dbname",$username,$password);echo "连接成功"."<br>";$pdo->setAttribute(PDO::ATTR_CASE,PDO::CASE_UPPER);
输出:连接成功

2.使用问号参数来准备SQL语句

$sql ="select * from fate where `ID`=?";$statement=$pdo->query("select * from fate where `ID`=3 ");var_dump($statement->fetch());echo "<br>";$stmt2 = $pdo->prepare($sql);$stmt2 ->execute(array(3));var_dump($stmt2->fetch());
输出:array(6) {["ID"]=>string(1) "3"0]=>string(1) "3"["name"]=>string(7) "luncher"[1]=>string(7) "luncher"["AGE"]=>string(2) "56"[2]=>string(2) "56"}array(6) {["ID"]=>string(1) "3"[0]=>string(1) "3"["name"]=>string(7) "luncher"[1]=>string(7) "luncher"["AGE"]=>string(2) "56"[2]=>string(2) "56"}

3.使用命名参数来准备SQL语句

$query = "insert into tp_user (ID,name,gender)values(:ID,:name ,:gender)";//准备语句$stmt1 = $pdo->prepare($query);// 执行查询$stmt1->execute(array('ID'=> 1,':name' => '张三', ':gender' => '男'));//再次执行$stmt1->execute(array('ID'=> 2,':name' => '李四', ':gender' => '女'));echo "插入成功!","<br>";
输出;插入成功!

推荐:2021年PHP面试题大汇总(收藏)》《php视频教程 总结

以上是内存溢出为你收集整理的对PHP中的prepare()方法的解析全部内容,希望文章能够帮你解决对PHP中的prepare()方法的解析所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/sjk/1152760.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存