每次发送查询语句给MysqL服务时,都必须解析该查询的语法,确保结构正确并能够执行。这是这个过程中必要的步骤,但也确实带来了一些开销。做一次是必要的,但是如果反复地执行相同的查询,批量插入多行时只改变列值,准备语句会在服务器上缓存查询的语法和执行过程,而只在服务器和客户端之间传输有变化的列值,以此来消除这些额外的开销。
首先我们来看一下PDO::prepare
的语法:
public PDO::prepare ( string $statement , array $driver_options = array() ) : PDOStatement
$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) 30]=>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视频教程》
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。