mysql prepare statement

在 MySQL 中,PREPARE 和 EXECUTE 语句可以用来执行预编译的 SQL 语句。然而,MySQL 的语法略有不同于你提供的示例。

以下是在 MySQL 中正确使用 PREPARE 和 EXECUTE 的示例:

复制代码
-- Prepare the statement
PREPARE stmt FROM 'SELECT * FROM bigtable WHERE name =?';

-- Execute the prepared statement with a parameter
SET @name = 'John';
EXECUTE stmt USING @name;

-- Drop the prepared statement
DEALLOCATE PREPARE stmt;

在这个示例中,我们首先使用 PREPARE 语句来准备一个带有参数的 SQL 语句。然后,我们使用 SET 语句来设置参数的值,并使用 EXECUTE 语句来执行预编译的 SQL 语句。最后,我们使用 DEALLOCATE PREPARE 语句来释放预编译的语句。

注意,MySQL 不支持使用 USING 关键字直接传递参数值,而是需要先将参数值设置到一个变量中,然后在 EXECUTE 语句中引用这个变量。

复制代码
示例:
mysql> PREPARE stmt FROM 'SELECT * FROM bigtable WHERE name =?';
Query OK, 0 rows affected (0.00 sec)
Statement prepared

mysql>
mysql> SET @name = 'Jone1829488e9aaaa';
Query OK, 0 rows affected (0.00 sec)

mysql> EXECUTE stmt USING @name;
+----+-------------------+------+--------------------+
| id | name              | age  | email              |
+----+-------------------+------+--------------------+
|  1 | Jone1829488e9aaaa |   38 | test1@baomidou.com |
+----+-------------------+------+--------------------+
1 row in set (3.84 sec)

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

mysql>
相关推荐
tonysh_zds1 小时前
windows pip install pysqlite3 安装失败处理
数据库·sqlite·pip
rising start1 小时前
一、数据库分类及SQLite入门
数据库·sqlite
5***E6857 小时前
【SQL】写SQL查询时,常用到的日期函数
数据库·sql
c***21298 小时前
Springboot3学习(5、Druid使用及配置)
android·学习
遇见火星8 小时前
CentOS7 通过源码安装 Redis
数据库·redis·缓存
Mr.朱鹏8 小时前
RocketMQ安装与部署指南
java·数据库·spring·oracle·maven·rocketmq·seata
Coder-coco8 小时前
个人健康管理|基于springboot+vue+个人健康管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·mysql·论文
K哥11258 小时前
【9天Redis系列】基础+全局命令
数据库·redis·缓存
修炼者8 小时前
【Android 进阶】别再强转 Context 了!手把手教你优雅解耦 View 与 Activity
android·android studio
s***46988 小时前
【玩转全栈】----Django模板语法、请求与响应
数据库·python·django