我有一个表foo
,其中NOT NULL
列的默认名称为message
:
CREATE TABLE foo(
id int PRIMARY KEY,
message varchar(64) NOT NULL DEFAULT 'Hello'
)
存储过程bar
可插入foo
:
CREATE PROCEDURE bar(
i_id int,
i_message varchar(64)
)
BEGIN
-- other logic
IF i_message IS NOT NULL THEN
INSERT INTO foo (id, message) VALUES (i_id, i_message);
ELSE
INSERT INTO foo (id, message) VALUES (i_id, DEFAULT);
-- could also be: INSERT INTO foo (id) VALUES (i_id);
END IF;
END;
你可以看到,我必须有条件地分支,以便我的插入使用默认值i_message
为空。这对于一个列来说很好,但考虑foo
是否还有更多NOT NULL DEFAULT
列 - 语法会变得难以处理。
我是否可以使用一种语法来指定插入的值如果为null则应该回退到默认值?我尝试了以下但可以理解的是语法错误:
INSERT INTO foo (id, message) VALUES (i_id, COALESCE(i_message, DEFAULT));
INSERT INTO foo (id, message) VALUES (i_id, IFNULL(i_message, DEFAULT));
答案 0 :(得分:21)
INSERT INTO foo (id, message)
VALUES
(i_id, IFNULL(i_message,DEFAULT(message)));