在 MySQL 中创建 View 时,我在创建的 View 中看不到具有 NULL 值的行。
和表状态
所以,我想使用下面的 SQL 代码从表 mail_prijava
和表 status
创建 VIEW
CREATE OR REPLACE VIEW
v_mail_prijava_test
AS
SELECT
mail_prijava.id,
mail_prijava.naselje AS naselje,
mail_prijava.ulica AS ulica,
mail_prijava.email AS email,
mail_prijava.napomena AS napomena,
IFNULL(status.opis AS "test") AS status
DATE_FORMAT(datum_unosa, "%d.%m.%Y.") AS datum_servisa,
vrijeme_unosa
FROM mail_prijava
INNER JOIN status ON status.id = mail_prijava.status_id
问题是表 mail_prijava
中具有空值的行没有显示,我想知道为什么会这样,是否可以在创建的 View 中显示具有 NULL 的行。
谢谢
最佳答案
要获取所有行,包括那些在 status
表中没有任何匹配项的行,您需要使用 left join
而不是 inner join
。
改变这个:
INNER JOIN status ON status.id = mail_prijava.status_id
对此:
LEFT JOIN status ON status.id = mail_prijava.status_id
此外,您的 IFNULL 行看起来很奇怪,您可能想要:
IFNULL(status.opis, "test") AS status -- this will show "test" as status if it's null
关于mysql - 使用 MySQL 在创建的 VIEW 中看不到 NULL 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37228623/