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');
いくつかの奇妙な事はあなたのスキーマ内にあります。 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
冗長性を呼び出すための固定のお礼 – MarkM