简体   繁体   English

外联接多表

[英]Outer join multiple table

I have 4 table that I want to join: 我有4个表要加入:

tbl_transaksi_header
--------------------
kode_transaksi
kode_user
nama_penerima
email_penerima
alamat_penerima
bank
telpon


tbl_konfirmasi
--------------------
id
kode
member
namarekening

tbl_user
-------------------
kode_user
username_user

tbl_transaksi_detail
---------------------
kode_transaksi
harga
jumlah
status

I want to show all data including NULL in nama_rek. 我想在nama_rek中显示所有数据,包括NULL。

I tried this: 我尝试了这个:

SELECT t.status, t.kode_transaksi kode, u.username_user nama_user, t.nama_penerima penerima, t.telpon, t.bank, sum(d.harga*d.jumlah) total,k.namarekening nama_rek
FROM tbl_transaksi_header t
    JOIN tbl_user u
        ON t.kode_user=u.kode_user
    JOIN tbl_transaksi_detail d
        ON t.kode_transaksi=d.kode_transaksi
    LEFT OUTER JOIN tbl_konfirmasi k
        ON t.kode_transaksi=k.kode

Work fine but not showing null result, only showing 1 row result. 工作正常,但不显示空结果,仅显示1行结果。 I want something like this: 我想要这样的东西:

status  kode    nama_user   penerima    telpn   bank    total   nama_rek
xxx     xxx     xxx         xxx         xxx     xxx     xxx     NULL
xxx     xxx     xxx         xxx         xxx     xxx     xxx     NULL
xxx     xxx     xxx         xxx         xxx     xxx     xxx     yyy
xxx     xxx     xxx         xxx         xxx     xxx     xxx     NULL

Sample data: 样本数据:

kode_transaksi  kode_user   nama_penerima   email_penerima  alamat_penerima bank    telpon
kd1             1           john            some@email.com  florida         Bank A  088833221
kd2             2           elsa            some@email.com  uk              Bank B  088833222
kd3             1           roy             some@email.com  manhattan       Bank C  088833223

id  kode    member  namarekening
1   kd1     paul    paul

kode_user   username_user
1           paul
2           elena

kode_transaksi  harga   jumlah  status
kd1             10      2       process
kd1             5       2       process
kd1             5       1       process
kd2             4       3       pending
kd2             3       4       pending
kd3             2       3       pending

I want this output: 我想要这个输出:

status  kode    nama_user   penerima    telpon      bank    total   nama_rek
process kd1     paul        john        088833221   Bank A  35      paul
pending kd2     elena       elsa        088833222   Bank B  24      NULL
pending kd2     elena       roy         088833223   Bank C  6       NULL

Your join is fine; 您的加入很好; the problem is that you have a SUM() in your select with no GROUP BY . 问题是您的选择中有一个SUM() ,没有GROUP BY Try this: 尝试这个:

SELECT  t.kode_transaksi kode, u.username_user nama_user, t.nama_penerima penerima, t.telpon, t.bank, sum(d.harga*d.jumlah) total,k.namarekening nama_rek
FROM tbl_transaksi_header t
    JOIN tbl_user u
        ON t.kode_user=u.kode_user
    JOIN tbl_transaksi_detail d
        ON t.kode_transaksi=d.kode_transaksi
    LEFT OUTER JOIN tbl_konfirmasi k
        ON t.kode_transaksi=k.kode
GROUP BY
    t.kode_transaksi, u.username_user, t.nama_penerima , t.telpon, t.bank,k.namarekening 

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM