3

羊の名前と兄弟と姉妹の数を示す sql ステートメントを作成する必要があります。

これは私のSQLスクリプトです:

create table breeder (
breederNumber   number(3) primary key,
name            varchar2(20),
residence       varchar2(20),
password        varchar2(20)
);

create table race (
raceCode        varchar2(2) primary key,
raceName        varchar2(20) not null
);

create table sheep (
earTagNumber    number(2) primary key,
father          number(2),
mother          number(2),
raceCode        varchar2(2),
name            varchar2(20),
previousBreeder number(3),
genotype        varchar2(7),
gender          varchar2(1) check (gender = 'M' OR gender = 'F'),

constraint fk_previousBreeder foreign key (previousBreeder) references breeder(breederNummer) on delete cascade,
constraint rk_raceCode foreign key (raceCode) references race(raceCode) on delete cascade,
constraint fk_mother foreign key (mother) references sheep(earTagNumber) on delete cascade,
constraint fk_father foreign key (father) references sheep(earTagNumber) on delete cascade
);

結果は次のようになります

外部結合を使用することになっていますが、SQL ステートメントがどのように表示されるかわかりません。

誰でも私を助けることができますか?

前もって感謝します!

4

1 に答える 1

1
select s1.earTagNumber, max(s1.name), count(s2.earTagNumber) 
 from sheep s1
 left join sheep s2 on (s1.father=s2.father) or (s1.mother=s2.mother)
group by s1.earTagNumber
于 2012-11-29T11:17:41.123 に答える