是否可以为mysql存储过程设置默认参数?

时间:2009-06-11 18:23:33

标签: sql mysql stored-procedures default-value

我已经用Google搜索并继续提出“不可能”但这些帖子的日期是2005年至2007年,所以我想知道这是否已经改变了。代码示例:

CREATE PROCEDURE `blah`
(
  myDefaultParam int = 0 -- This breaks the code for some reason
)
BEGIN
  -- Do something here
END

其中一个解决方案是传递null,然后检查null并设置变量。我不想那样做,我不应该这样做。如果这是真的那么MySql开发者需要醒来,因为我可以用MSSQL做更多的事情。

6 个答案:

答案 0 :(得分:63)

这仍然不可能。

答案 1 :(得分:43)

我们通过在存储过程中添加一个简单的IF语句来解决这个限制。实际上,只要我们想在DB中保存默认值,我们就会传递一个空字符串。

CREATE DEFINER=`test`@`%` PROCEDURE `myProc`(IN myVarParam VARCHAR(40))
BEGIN
  IF myVarParam = '' THEN SET myVarParam = 'default-value'; END IF;

  ...your code here...
END

答案 2 :(得分:18)

SET myParam = IFNULL(myParam, 0);

说明:IFNULL(expression_1, expression_2)

如果IFNULL不是expression_1,则expression_1函数会返回NULL;否则返回expression_2IFNULL函数根据使用它的上下文返回一个字符串或数字。

答案 3 :(得分:11)

如果您查看CREATE PROCEDURE Syntax最新的MySQL版本,您会看到该过程参数只能包含IN / OUT / INOUT说明符,参数名称和类型。

因此,默认值在最新的MySQL版本中仍然不可用。

答案 4 :(得分:4)

不幸的是,MySQL不支持DEFAULT参数值,因此:

CREATE PROCEDURE `blah`
(
  myDefaultParam int DEFAULT 0
)
BEGIN
  -- Do something here
END

返回错误:

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual
that corresponds to your MySQL server version for the right syntax to use 
near 'DEFAULT 0) BEGIN END' at line 3

要解决此限制,只需创建将默认值分配给原始过程的其他过程:

DELIMITER //

DROP PROCEDURE IF EXISTS blah//
DROP PROCEDURE IF EXISTS blah2//
DROP PROCEDURE IF EXISTS blah1//
DROP PROCEDURE IF EXISTS blah0//

CREATE PROCEDURE blah(param1 INT UNSIGNED, param2 INT UNSIGNED)
BEGIN
    SELECT param1, param2;
END;
//

CREATE PROCEDURE blah2(param1 INT UNSIGNED, param2 INT UNSIGNED)
BEGIN
    CALL blah(param1, param2);
END;
//

CREATE PROCEDURE blah1(param1 INT UNSIGNED)
BEGIN
    CALL blah2(param1, 3);
END;
//

CREATE PROCEDURE blah0()
BEGIN
    CALL blah1(4);
END;
//

然后,运行这个:

CALL blah(1, 1);
CALL blah2(2, 2);
CALL blah1(3);
CALL blah0();

将返回:

+--------+--------+
| param1 | param2 |
+--------+--------+
|      1 |      1 |
+--------+--------+
1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

+--------+--------+
| param1 | param2 |
+--------+--------+
|      2 |      2 |
+--------+--------+
1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

+--------+--------+
| param1 | param2 |
+--------+--------+
|      3 |      3 |
+--------+--------+
1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

+--------+--------+
| param1 | param2 |
+--------+--------+
|      4 |      3 |
+--------+--------+
1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

然后,如果您确保仅使用blah2()blah1()blah0()过程,则在向第三个参数添加第三个参数时,不需要立即更新代码blah()程序。

答案 5 :(得分:1)

不,MySQL存储的例程语法不支持此功能。

随时在bugs.mysql.com提交功能请求。