多到一個(產品只能有一個商店)
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
是應該是商店的孩子的產品,還是可以在許多商店出現同樣的產品?如果相同的產品可以出現在許多商店,你正在尋找一個多對多的關係,而不是一對多的關係 –