我有一个表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;
您可以看到,我必须有条件地分支才能让我的插入使用默认值 ifi_message
为 null。这对于一列来说很好,但考虑如果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));