如何在 MySQL 中使用准备好的语句?
mysqlmysqli database
MySQL 服务器支持准备好的语句,这在我们想要运行许多仅在非常小的细节上有所不同的查询时非常有用。我们可以准备一个语句,然后多次执行它,每次使用不同的数据值。基本上,MySQL 中的准备好的语句利用了客户端/服务器二进制协议。准备好的语句提供了增强的性能,因为完整的语句只被服务器解析一次。
以下是在 MySQL 中使用准备好的语句的步骤 −
准备语句
这是我们使用 PREPARE 语句准备语句的第一步。例如,以下是使用来自‘Tender’ 的数据准备的语句表 −
示例
PREPARE stmt FROM ‘Select tender_value from Tender Where Companyname = ?;’
执行 PREPARED 语句
第二步,我们将使用 ‘PREPARE’ 语句执行已准备好的语句。例如,我们将使用以下语法 −
示例
EXECUTE stmt USING @variable_name;
此处 @variable_name 将具有我们想要在 PREPARE 语句中的 ? 位置传递的值。在执行准备好的语句之前,我们需要使用 SET 语句设置 @variable_name 的值。
DEALLOCATE PREPARED 语句
这是最后一步,我们将借助 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)