from用法 prepare_<转>MYSQL PREPARE用法详细解释

如果你的MySQL 版本是 5.0.7以上

mysql>

PREPARE STMT FROM "SELECT * FROM tbl LIMIT ?";

mysql>

EXECUTE STMT USING @a;

mysql>

SET @skip=1; SET @numrows=5;

mysql>

PREPARE STMT FROM "SELECT * FROM tbl LIMIT ?, ?";

mysql>

EXECUTE STMT USING @skip, @numrows;

使用 PREPARE 的几个注意点:

A:

PREPARE

stmt_name

FROM

preparable_stmt

;

预定义一个语句,并将它赋给 stmt_name ,stmt_name 是不区分大小写的。

B:

即使 preparable_stmt 语句中的 ? 所代表的是一个字符串,你也不需要将 ? 用引号包含起来。

C:

如果新的 PREPARE 语句使用了一个已存在的 stmt_name ,那么原有的将被立即释放!

即使这个新的 PREPARE 语句因为错误而不能被正确执行。

D:

PREPARE stmt_name 的作用域是当前客户端连接会话可见。

E:

要释放一个预定义语句的资源,可以使用 DEALLOCATE PREPARE 句法。

F:

EXECUTE

stmt_name

句法中,如果 stmt_name 不存在,将会引发一个错误。

G:

如果在终止客户端连接会话时,没有显式地调用 DEALLOCATE PREPARE 句法释放资源,服务器端会自己动释放它。

H:

在预定义语句中,CREATE TABLE,

DELETE

,

DO

,

INSERT

,

REPLACE

,

SELECT

,

SET

,

UPDATE

, 和大部分的

SHOW

句法被支持。

G:

PREPARE 语句不可以用于存储过程,自定义函数!但从 MySQL 5.0.13 开始,它可以被用于存储过程,仍不支持在函数中使用!

下面给个示例:

CREATE PROCEDURE `p1`(

IN id INT UNSIGNED,

IN name VARCHAR(11)

)

BEGIN

lable_exit: BEGIN

SET @SqlCmd = 'SELECT * FROM tA ';

IF id IS NOT NULL THEN

SET @SqlCmd = CONCAT(@SqlCmd , 'WHERE id=?');

PREPARE stmt FROM @SqlCmd;

SET @a = id;

EXECUTE stmt USING @a;

LEAVE lable_exit;

END IF;

IF name IS NOT NULL THEN

SET @SqlCmd = CONCAT(@SqlCmd , 'WHERE name LIKE ?');

PREPARE stmt FROM @SqlCmd;

SET @a = CONCAT(name, '%');

EXECUTE stmt USING @a;

LEAVE lable_exit;

END IF;

END lable_exit;

END;

CALL `p1`(1,NULL);

CALL `p1`(NULL,'QQ');

DROP PROCEDURE `p1`;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值