2017-04-26 15 views
0

ステータスが「アクティブ」であるすべての顧客をリストするクエリが必要です。このクエリは、アクティブとしてマークされた顧客のリストを返します。私の問題は、私が他のテーブルを参照するテーブルを照会することで失われていることです。ここに私のスキーマがあります。PostgreSQLでスキーマをクエリする

CREATE TABLE Customer (
    ID BIGSERIAL PRIMARY KEY NOT NULL, 
    fNAME TEXT NOT NULL, 
    lNAME TEXT NOT NULL, 
    create_date DATE NOT NULL DEFAULT NOW() 
); 

CREATE TABLE CustomerStatus (
    recordID BIGSERIAL NOT NULL, 
    ID BIGSERIAL REFERENCES Customer NOT NULL, 
    status TEXT NOT NULL, 
    create_date DATE NOT NULL DEFAULT NOW() 
); 

INSERT INTO Customer (fNAME, lNAME) VALUES ('MARK', 'JOHNSON'), ('ERICK', 'DAWN'), ('MAY', 'ERICKSON'), ('JESS', 'MARTIN'); 

INSERT INTO CustomerStatus (ID, status) VALUES (1, 'pending'), (1, 'active');  

INSERT INTO CustomerStatus (ID, status) VALUES (2, 'pending'), (2, 'active'), (2, 'cancelled');  

INSERT INTO CustomerStatus (ID, status) VALUES (3, 'pending'), (3, 'active'); 

INSERT INTO CustomerStatus (ID, status) VALUES (4, 'pending'); 
+0

いくつかの奇妙な事はあなたのスキーマ内にあります。 1. Customer.ID NOT NULL制約は冗長です。 2.なぜCustomerStatus.IDにBIGSERIAL型があるのですか?私はそれがBIGINTであるべきだと思います。 3.主な質問(問題を説明する必要があります) - 1カスタマーは複数のCustomerStatusを持つことができますか? yesの場合(CustomerStatusテーブルがCustomerStatusHistoryのようなもの)、CustomerStatusにUNIQUE(ID、create_date)という制約を追加します。それ以外の場合、制約はUNIQUE(ID)であり、顧客は1つの状況のみを持つことができます。 – Eugene

+0

冗長性を呼び出すための固定のお礼 – MarkM

答えて

0

私はそのRECORD_IDを前提とする勇気を取ったが、シリアルである=>最新のidがこのQRYを生成するために、最後のようになります。

t=# with a as (
    select *, max(recordid) over (partition by cs.id) 
    from Customer c 
    join CustomerStatus cs on cs.id = c.id 
) 
select * 
from a 
where recordid=max and status = 'active'; 
id | fname | lname | create_date | recordid | id | status | create_date | max 
----+-------+----------+-------------+----------+----+--------+-------------+----- 
    1 | MARK | JOHNSON | 2017-04-27 |  2 | 1 | active | 2017-04-27 | 2 
    3 | MAY | ERICKSON | 2017-04-27 |  7 | 3 | active | 2017-04-27 | 7 
(2 rows) 

Time: 0.450 ms 
関連する問題