特定の値を持たない行を表示するには?

トラヴィスボーエン:

私はSQLに比較的新しいですし、私はそれのためにテーブルに値を追加することなく、その中の特定の値を持たない行を表示する必要があります。私が働いているテーブルは以下のとおりです。

 Select * from PERSON;
+-------+-------+---------+--------+---------+----------+
| idnum | fname | lname   | rname  | private | linkblue |
+-------+-------+---------+--------+---------+----------+
| 11111 | Bob   | Bobsley | Robert |       0 | bob1111  |
| 93210 | Bowen | Travis  | Luke   |       1 | tlbo232  |
+-------+-------+---------+--------+---------+----------+
Select * from ADVISOR;
+---------+---------+-------+-------+ You can ignore the sdate and edate
| student | advisor | sdate | edate |
+---------+---------+-------+-------+
|   11111 |   93210 | NULL  | NULL  |
|   93210 |   11111 | NULL  | NULL  |
+---------+---------+-------+-------+
Select * from DIGITAL;
+----------+-------+-------------------------+
| smtype   | idnum | smaddr                  |
+----------+-------+-------------------------+
| email    | 11111 | [email protected]         |
| email    | 93210 | [email protected]         |
| facebook | 11111 | [email protected]    |
| facebook | 93210 | [email protected]    |
| twitter  | 11111 | twitter.com/bob.bobsley |
+----------+-------+-------------------------+

目標は、学生、自分の電子メール、アドバイザーの名前、およびそのさえずりの名前の名前をプリントアウトすることです。このようなものはそう:

+------------+-----------+-----------------+--------------------+-------------------+-------------------------+
| First Name | Last Name | Email           | Advisor First Name | Advisor Last Name | Advisor Twitter         |
+------------+-----------+-----------------+--------------------+-------------------+-------------------------+
| Bowen      | Travis    | [email protected] | Bob                | Bobsley           | twitter.com/bob.bobsley |
+------------+-----------+-----------------+--------------------+-------------------+-------------------------+

どちらから来ています:

select 
    P.fname as 'First Name', 
    P.lname as 'Last Name', 
    D.smaddr as 'Email', 
    AdivsorList.fname as 'Advisor First Name',
    AdivsorList.lname as 'Advisor Last Name', 
    AdivsorList.smaddr as 'Advisor Twitter' 
from PERSON P 
LEFT OUTER JOIN DIGITAL D ON P.idnum = D.idnum 
LEFT OUTER JOIN (
    SELECT P1.fname, P1.lname, A.advisor, D1.smaddr, D1.smtype
    from ADVISOR A 
    LEFT OUTER JOIN PERSON P1 ON A.student = P1.idnum 
    LEFT OUTER JOIN DIGITAL D1 ON P1.idnum = D1.idnum
) as AdivsorList ON P.idnum = AdivsorList.advisor 
where D.smtype = 'email' AND AdivsorList.smtype = 'twitter';

出力は、2つの行を示すべきであるが、それが表示されないように行の1つは、さえずりを持っていません。私はそれを表示する方法を探しています。

GMB:

それは、一連で行うことができますleft join(S)

select
    ps.fname  student_fname,
    ps.lname  student_lname,
    ds.smaddr student_email
    pa.fname  adviser_fname,
    pa.lname  adviser_lname,
    da.smaddr advisor_twitter
from person ps
left join advisor a  on a.student = ps.idnum
left join person  pa on pa.idnum  = a.advisor
left join digital ds on ds.idnum  = ps.idnum and ds.smtype = 'email'
left join digital da on da.idnum  = pa.idnum and da.smtype = 'twitter'

おすすめ

転載: http://10.200.1.11:23101/article/api/json?id=5743&siteId=1