美文网首页
预处理语句与存储过程(Prepared statements a

预处理语句与存储过程(Prepared statements a

作者: 咚门 | 来源:发表于2016-05-25 10:52 被阅读217次

很多更成熟的数据库都支持预处理语句(prepared statements,预先准备好的语句)的概念。

什么是预处理语句?可以把它看作是 程序想要运行的 SQL 的一种编译过的模板(a kind of compiled template for the SQL),它可以使用变量参数进行定制。

预处理语句可以带来两大好处:

  • 查询只需解析(或预处理)一次但可以 代入相同或不同的参数来 执行多次。当查询预处理之后,数据库将分析、编译和优化执行该查询的计划(When the query is prepared, the database will analyze, compile and optimize its plan for executing the query)。对于复杂的查询,此过程要花费较长的时间,如果需要以不同参数多次重复相同的查询,那么该过程将大大降低应用程序的速度(咚门:cao,看不出这是说的是普通SQL语句,还是预处理语句)。通过使用预处理语句,可以避免重复分析/编译/优化周期。这意味着预处理语句占用更少的资源,因而运行得更快
  • 提供给预处理语句的参数不需要用引号括起来,驱动程序会自动处理。如果应用程序只使用预处理语句,开发者就能够确保不会发生SQL 注入。(然而,如果查询的其他部分是由未转义的输入来构建的,则仍存在 SQL 注入的风险)。

预处理语句如此有用,以至于它们唯一的特性是在驱动程序不支持的时PDO 将模拟处理。这样可以确保不管数据库是否具有这样的功能,都可以确保应用程序可以用相同的数据访问模式。

Example #1

用预处理语句进行重复插入

下面例子通过用 name 和 value 替代相应的命名占位符来执行一个插入查询

<?php
$stmt = $dbh->prepare("INSERT INTO REGISTRY (name, value) VALUES (:name, :value)");
$stmt->bindParam(':name', $name);
$stmt->bindParam(':value', $value);

// 插入一行
$name = 'one';
$value = 1;
$stmt->execute();

//  用不同的值插入另一行
$name = 'two';
$value = 2;
$stmt->execute();
?>

Example #2

用预处理语句进行重复插入

下面例子通过用 name 和 value 取代 ? 占位符的位置来执行一条插入查询。

<?php
$stmt = $dbh->prepare("INSERT INTO REGISTRY (name, value) VALUES (?, ?)");
$stmt->bindParam(1, $name);
$stmt->bindParam(2, $value);

// 插入一行
$name = 'one';
$value = 1;
$stmt->execute();

// 用不同的值插入另一行
$name = 'two';
$value = 2;
$stmt->execute();
?>

Example #3

使用预处理语句获取数据

下面例子根据表单提供的键值来获取数据。用户的输入被自动用引号括起来,因此不会有 SQL 注入攻击的危险。

<?php
$stmt = $dbh->prepare("SELECT * FROM REGISTRY where name = ?");
if ($stmt->execute(array($_GET['name']))) {
  while ($row = $stmt->fetch()) {
    print_r($row);
  }
}
?>

如果数据库驱动支持,应用程序还可以绑定输出和输入参数.输出参数通常用于从存储过程获取值。输出参数使用起来比输入参数要稍微复杂一些,因为当绑定一个输出参数时,必须知道给定参数的长度。如果为参数绑定的值大于建议的长度,就会产生一个错误。

Example #4

带输出参数调用存储过程

<?php
$stmt = $dbh->prepare("CALL sp_returns_string(?)");
$stmt->bindParam(1, $return_value, PDO::PARAM_STR, 4000); 

// 调用存储过程
$stmt->execute();

print "procedure returned $return_value\n";
?>

还可以指定同时具有输入和输出值的参数,其语法类似于输出参数。在下一个例子中,字符串“hello”被传递给存储过程,当存储过程返回时,hello 被替换为该存储过程返回的值。

Example #5

带输入/输出参数调用存储过程

<?php
$stmt = $dbh->prepare("CALL sp_takes_string_returns_string(?)");
$value = 'hello';
$stmt->bindParam(1, $value, PDO::PARAM_STR|PDO::PARAM_INPUT_OUTPUT, 4000); 

// 调用存储过程
$stmt->execute();

print "procedure returned $value\n";
?>

Example #6

占位符的无效使用

<?php
$stmt = $dbh->prepare("SELECT * FROM REGISTRY where name LIKE '%?%'");
$stmt->execute(array($_GET['name']));

// 占位符必须被用在整个值的位置
$stmt = $dbh->prepare("SELECT * FROM REGISTRY where name LIKE ?");
$stmt->execute(array("%$_GET[name]%"));
?>

相关文章

  • 预处理语句与存储过程(Prepared statements a

    很多更成熟的数据库都支持预处理语句(prepared statements,预先准备好的语句)的概念。 什么是预处...

  • PDO:什么是预处理?

    什么是预处理? 成熟的数据库都支持预处理语句(Prepared Statements)的概念。 它们是什么东西?你...

  • Using Prepared Statements

    This page covers the following topics: Overview of Prepar...

  • 【php:函数参考】数据库扩展

    数据库抽象层 ODBC PDO 连接与连接管理 事务与自动提交 预处理语句与存储过程 //绑定参数, 防止 sql...

  • 随记

    MySQL与 PostgreSQL 预处理(Prepared) 匿名占位符 MySQL: 使用 ? 作为匿名占位符...

  • 浅谈存储过程

    【1】什么是过程?过程与函数的区别?什么是存储过程??? 存储过程:存储在数据库中的封装了若干条SQL语句的过程(...

  • SQL第19课:存储过程

    存储过程 存储过程是由SQL语句和控制语句构成的语句串(语句集合)。它不仅可以带有输入参数还可以带有输出参数,存储...

  • 8、MySQL存储过程

    存储过程 存储过程是一个SQL语句集合,当主动去调用存储过程时,其中内部的SQL语句会按照逻辑执行。 1、创建存储...

  • mysql——预处理Prepared

    某需求某一条 SQL 语句可能会被反复调用执行,或者每次执行的时候只有个别的值不同(比如 select 的 whe...

  • 《mysql必知必会》读书实战笔记23-存储过程

    第23章 使用存储过程 23.1 存储过程 存储过程,是为了完成一个复杂任务,而编写的多条sql语句的集合,语句执...

网友评论

      本文标题:预处理语句与存储过程(Prepared statements a

      本文链接:https://www.haomeiwen.com/subject/xjctdttx.html