5

サンプル スキーマとデータを含むSQLFiddleを次に示します。

親の「構造」レコードがリンクされているすべてのパートナー (「item_version_partner」レコードを介して) に「item_version」レコードがリンクされていない「item_version」レコードにリンクされている「構造」レコードを見つけることができる必要があります (その偉大な孫テーブル 'structure_version_range_partner' を介して)。

フィドルにデータが読み込まれると、次のことが期待されます。

アイテム バージョン 1はPartner 1Partner 2の両方にリンクされており、その親であるStructure 1にもリンクされているため、結果には含まれませ

アイテム バージョン 2はPartner 2にのみリンクされていますが、その親 ( Structure 2 ) はPartner 1 Partner 2の両方にリンクされているため、結果に含まれているはずです。

つまり、 Structure 2レコードが唯一の結果として表示されます。

それが明確であることを願っています!

更新 1: 使用したスキーマとテスト データは次のとおりです。

CREATE TABLE partner (
  id bigint(20) NOT NULL AUTO_INCREMENT,
  partner_name varchar(255) NOT NULL,
  PRIMARY KEY (id)
);

CREATE TABLE structure (
  id bigint(20) NOT NULL AUTO_INCREMENT,
  description varchar(50) NOT NULL,
  PRIMARY KEY (id)
);

CREATE TABLE structure_version (
  id bigint(20) NOT NULL AUTO_INCREMENT,
  structure_id bigint(20) NOT NULL,
  PRIMARY KEY (id),
  KEY fk_st_structure (structure_id),
  CONSTRAINT fk_st_structure FOREIGN KEY (structure_id) REFERENCES structure (id)
);

CREATE TABLE structure_version_range (
  id bigint(20) NOT NULL AUTO_INCREMENT,
  structure_version_id bigint(20) NOT NULL,
  PRIMARY KEY (id),
  KEY fk_svr_structure_version (structure_version_id),
  CONSTRAINT fk_svr_structure_version FOREIGN KEY (structure_version_id) REFERENCES structure_version (id)
);

CREATE TABLE structure_version_range_partner (
  id bigint(20) NOT NULL AUTO_INCREMENT,
  partner_id bigint(20) NOT NULL,
  structure_version_range_id bigint(20) NOT NULL,
  PRIMARY KEY (id),
  KEY fk_svrp_version_range (structure_version_range_id),
  KEY fk_svrp_partner (partner_id),
  CONSTRAINT fk_svrp_partner FOREIGN KEY (partner_id) REFERENCES partner (id),
  CONSTRAINT fk_svrp_version_range FOREIGN KEY (structure_version_range_id) REFERENCES structure_version_range (id)
);

CREATE TABLE item_version (
  id bigint(20) NOT NULL AUTO_INCREMENT,
  structure_id bigint(20) NOT NULL,
  item_version_name varchar(255) NOT NULL,  
  PRIMARY KEY (id),
  KEY fk_iv_structure (structure_id),
  CONSTRAINT fk_iv_structure FOREIGN KEY (structure_id) REFERENCES structure (id)
);

CREATE TABLE item_version_partner (
  id bigint(20) NOT NULL AUTO_INCREMENT,
  item_version_id bigint(20) NOT NULL,
  partner_id bigint(20) NOT NULL,
  PRIMARY KEY (id),
  KEY fk_ivp_item_version (item_version_id),
  KEY fk_ivp_partner (partner_id),
  CONSTRAINT fk_ivp_item_version FOREIGN KEY (item_version_id) REFERENCES item_version (id),
  CONSTRAINT fk_ivp_partner FOREIGN KEY (partner_id) REFERENCES partner (id)
);

insert into partner values (1, 'Partner 1');
insert into partner values (2, 'Partner 2');

insert into structure values(1, 'Structure 1');
insert into structure values(2, 'Structure 2');

insert into structure_version values(1,1);
insert into structure_version values(2,2);

insert into structure_version_range values(1,1);
insert into structure_version_range values(2,2);

insert into structure_version_range_partner values(1,1,1);
insert into structure_version_range_partner values(2,2,1);
insert into structure_version_range_partner values(3,1,2);
insert into structure_version_range_partner values(4,2,2);

insert into item_version values(1,1,'Item Version 1');
insert into item_version values(2,2,'Item Version 2');

insert into item_version_partner values(1,1,1);
insert into item_version_partner values(2,1,2);
insert into item_version_partner values(3,2,1);
4

1 に答える 1

1

あなたの更新に基づいて、これが始まりになるはずです。

Select s.Description From Structure s
inner join structure_version sv On sv.structure_id = s.id
inner join Structure_version_range svr on svr.structure_version_id = sv.id
inner join structure_version_range_partner svrp On svrp.structure_version_range_id = svr.structure_version_id
inner join item_version iv on iv.structure_id = s.id
Left join item_version_partner ivp On ivp.item_version_id = iv.ID and ivp.partner_id = svrp.partner_id
Where ivp.partner_id is null

概念は非常に単純です。それは、実装した正規化によって少し風が強くなっているだけです。2 つのテーブルから partner_ids を選択し、where 句を削除すると、その動作が示されます。

于 2013-07-11T22:33:58.123 に答える