多対1
(製品のみ1つの店舗を持つことができます)
create table store(
id int unsigned not null auto_increment,
store_name varchar(30) not null,
primary key(id)
);
Query OK, 0 rows affected (0.02 sec)
create table product(
id int unsigned not null auto_increment,
store_id int unsigned not null,
product_name varchar(30) not null,
price float not null,
primary key(id),
constraint product_store foreign key (store_id) references store(id)
);
Query OK, 0 rows affected (0.02 sec)
多対多
(製品は多くの店ですることができます)
create table store(
id int unsigned not null auto_increment,
store_name varchar(30) not null,
primary key(id)
);
Query OK, 0 rows affected (0.04 sec)
create table product(
id int unsigned not null auto_increment,
store_id int unsigned not null,
product_name varchar(30) not null,
price float not null,
primary key(id)
);
Query OK, 0 rows affected (0.01 sec)
create table product_store (
product_id int unsigned not null,
store_id int unsigned not null,
CONSTRAINT product_store_store foreign key (store_id) references store(id),
CONSTRAINT product_store_product foreign key (product_id) references product(id),
CONSTRAINT product_store_unique UNIQUE (product_id, store_id)
)
Query OK, 0 rows affected (0.02 sec)
保持する第三のテーブルを作成します店舗IDごとの商品ID。 – artm
は、店舗の子供であると思われる商品ですか、同じ商品が多くの店舗に表示されるのですか?同じ商品が多くの店舗に出現する可能性がある場合は、1対多数の関係ではなく、多対多の関係を探しています –