Ich benutze Mysql und ich habe eine schwierige Zeit versucht, die Ergebnisse von einer SELECT-Abfrage zu erhalten. Ich habe 3 Tische. Erste Tabellenabschnitte, zweite Tabellenabschnittsmitglieder und dritter Tabellenabschnittsmemberstatus (Daten in dieser Tabelle sind statisch).Mehrere Tabellen Joins mit WHERE-Klausel
select * from Sections;
| section_id | title | description | section_ownerid |
-------------------------------------------------------
| 1 | title1 | desc1 | 100 |
| 2 | title2 | desc2 | 100 |
| 3 | title3 | desc3 | 100 |
| 4 | title4 | desc4 | 100 |
| 5 | title5 | desc5 | 100 |
| 6 | title6 | desc6 | 100 |
select * from SectionMembers;
| SectionMembers_id | section_id | status_code | memberid |
------------------------------------------------------------
| 1 | 1 | 10 | 200 |
| 2 | 1 | 20 | 300 |
| 3 | 2 | 30 | 200 |
| 4 | 2 | 10 | 300 |
| 5 | 3 | 30 | 200 |
| 6 | 4 | 20 | 200 |
select * from MemberStatus;
| MemberStatus_id | status_code | status |
---------------------------------------------------
| 1 | 10 | PENDINGMEMBER |
| 2 | 20 | ACTIVEMEMBER |
| 3 | 30 | MEMBERREJECTED |
I verwendet verbindet Ergebnisse als
select distinct(a.section_id) as id,
a.title,
a.description,
c.status
from Sections a
left join SectionMembers b on a.section_id = b.section_id
inner join MemberStatus c on b.status_code = c.status_code
where (a.section_ownerid = 100 and b.memberid = 200)
or (a.section_ownerid = 100);
Aber ich bin nicht korrektes Ergebnis bekommen zu bekommen. Ich will Ergebnisse wie folgt:
| section_id | title | description | status |
------------------------------------------------------
| 1 | title1 | desc1 | PENDINGMEMBER |
| 2 | title2 | desc2 | ACTIVEMEMBER |
| 3 | title3 | desc3 | MEMBERREJECTED |
| 4 | title4 | desc4 | ACTIVEMEMBER |
| 5 | title5 | desc5 | NULL |
| 6 | title6 | desc6 | NULL |
Diese sehr gut gearbeitet. Danke Bluefuß. – Bhargav
@BhargavBonu Sie sind herzlich willkommen! :) – Taryn
Das hat geholfen! Danke !! 1 – normalUser