在MySQL中创建视图时,我无法在创建的视图中看到具有NULL值的行。
和表status
所以,我想使用下面的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
中具有空值的行,我想知道为什么会这样,并且可以在创建的视图中显示带有NULL的行。
谢谢
答案 0 :(得分:2)
要获取所有行,包括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