首页 > 数据库 > mysql教程 > 我们如何在 MySQL 中使用准备好的语句?

我们如何在 MySQL 中使用准备好的语句?

WBOY
发布: 2023-09-11 08:09:09
转载
841 人浏览过

我们如何在 MySQL 中使用准备好的语句?

MySQL 服务器支持准备好的语句,当我们想要运行许多仅在很小的细节上有所不同的查询时,这非常有用。我们可以准备一个语句,然后多次执行它,并且每次使用不同的数据值。基本上,MySQL 中的准备语句利用客户端/服务器二进制协议。准备好的语句可以提供增强的性能,因为服务器只解析一条完整的语句。

以下是在 MySQL 中使用准备好的语句的步骤 -

准备语句

这是我们使用 PREPARE 语句准备语句的第一步。例如,以下是使用“Tender”表中的数据编写的报表 -

示例

PREPARE stmt FROM ‘Select tender_value from Tender Where Companyname = ?;’
登录后复制

执行 PREPARED 语句

 这是我们将执行的第二步使用“PREPARE”语句准备的语句。例如,我们将使用以下语法执行准备好的语句 stmt -

示例

EXECUTE stmt USING @variable_name;
登录后复制

这里 @variable_name 将具有我们希望在 ? 处传递的值。在 PREPARE 语句中。在执行prepared语句之前,我们需要使用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)
登录后复制

以上是我们如何在 MySQL 中使用准备好的语句?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板