首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL存储过程没有输出正确的值

MySQL存储过程没有输出正确的值
EN

Stack Overflow用户
提问于 2015-02-11 22:28:16
回答 2查看 32关注 0票数 1

这必须是简单的,我只是错过了它。我试图运行这样一个存储过程;

代码语言:javascript
复制
DELIMITER $$
DROP PROCEDURE IF EXISTS Testing$$
CREATE  PROCEDURE `Testing`(out d varchar(10))
BEGIN
  select @v1 =  'Value 1';
  select @v2 =  'Value 2';
  select @v3 =  'Value 3';

  set d = @v1;
END$$

DELIMITER ;


call Testing(@d);
select d;

问题是当运行时,它会返回。

这对我来说毫无意义。对于试图将MySQL转换为MySQL的简单问题,很抱歉。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-02-11 22:57:05

正如我测试过的那样,@d在您的代码中不是任何变量,您使用它从过程中获取输出值。

但是您的最后一个选择@v3 = 'Value 3'在过程中作为控制台的输出工作。如您所见,输出为null,但列名为,选择@v3 = 'Value 3',而不是输出输出窗口中的过程。

希望它被清除了。

票数 1
EN

Stack Overflow用户

发布于 2015-02-11 23:03:32

Mysql在SELECT上有点古怪,下面的语句

代码语言:javascript
复制
select @v1 =  'Value 1';

实际上是一种比较;它将默认为NULL的@v1与value 1进行比较,后者将返回要分配值的null.If --使用:=

代码语言:javascript
复制
select @v1 :=  'Value 1';

或者,使用成套;

代码语言:javascript
复制
SET @v1 =  'Value 1';
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28465778

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档