我已经用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做更多的事情。
答案 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_2
。 IFNULL
函数根据使用它的上下文返回一个字符串或数字。
答案 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提交功能请求。