如何在MySQL中使用预处理语句?


MySQL服务器支持预处理语句,当我们想要运行许多只有细微差别(仅少量细节不同)的查询时,预处理语句非常有用。我们可以准备一条语句,然后多次执行它,每次使用不同的数据值。基本上,MySQL中的预处理语句利用了客户端/服务器二进制协议。预处理语句提供增强的性能,因为完整的语句只会被服务器解析一次。

以下是使用MySQL中预处理语句的步骤:

准备语句

这是第一步,我们将使用`PREPARE`语句准备一条语句。例如,以下是使用“Tender”表中的数据准备的语句:

示例

PREPARE stmt FROM ‘Select tender_value from Tender Where Companyname = ?;’

执行预处理语句

这是第二步,我们将使用`EXECUTE`语句执行已使用`PREPARE`语句准备的语句。例如,我们将使用以下语法执行已准备好的语句`stmt`:

示例

EXECUTE stmt USING @variable_name;

这里`@variable_name`将具有我们想要传递到`PREPARE`语句中的`?`位置的值。在执行预处理语句之前,我们需要使用`SET`语句设置`@variable_name`的值。

释放预处理语句

这是最后一步,我们将使用`DEALLOCATE`语句释放预处理语句。例如,我们将使用以下语法释放预处理语句`stmt`:

示例

DEALLOCATE PREPARE stmt;

以下是我们可以用来运行预处理语句的查询:

mysql> PREPARE stmt FROM 'SELECT tender_value from Tender WHERE
Companyname = ?';
Query OK, 0 rows affected (0.09 sec)
Statement prepared

mysql> SET @A = 'Singla Group.';
Query OK, 0 rows affected (0.00 sec)

mysql> EXECUTE stmt using @A;
+--------------+
| tender_value |
+--------------+
|   220.255997 |
+--------------+
1 row in set (0.07 sec)

mysql> DEALLOCATE PREPARE stmt;
Query OK, 0 rows affected (0.00 sec)

更新于:2020年6月20日

452 次浏览

启动你的职业生涯

通过完成课程获得认证

开始学习
广告