gpt4 book ai didi

mysql - 外键关系没有意义,有没有更好的方法?

转载 作者:搜寻专家 更新时间:2023-10-30 23:44:33 24 4
gpt4 key购买 nike

我在尝试理解我的表在我的数据库中应该如何关联时遇到了问题。我是初学者,并尝试自己研究。表格如下

    CREATE TABLE PIZZA
(
pizza_id INT AUTO_INCREMENT PRIMARY KEY,
pizza_name VARCHAR (255),
pizza_desc VARCHAR (255),
pizza_price DOUBLE
);

CREATE TABLE CUSTOMER
(
cust_id INT AUTO_INCREMENT PRIMARY KEY,
cust_first_name VARCHAR (255),
cust_last_name VARCHAR (255),
cust_street VARCHAR (255),
cust_apt VARCHAR (255),
cust_city VARCHAR (255),
cust_state CHAR(2),
cust_zip CHAR(5),
cust_home_phone CHAR(10),
cust_mobile_phone CHAR(10),
cust_other_phone CHAR(10)
);

CREATE TABLE PIZZA_ORDER
(
pizza_order_id INT AUTO_INCREMENT PRIMARY KEY,
pizza_id INT,
cust_id INT,
order_date TIMESTAMP,
order_quantity INT,
order_notes VARCHAR (255),
FOREIGN KEY (pizza_id) REFERENCES PIZZA(pizza_id),
FOREIGN KEY (cust_id) REFERENCES CUSTOMER(cust_id)
);

我的问题是,如果 PIZZA_ORDER 表中的记录有两个不同的比萨饼,这意味着两个不同的 pizza_ids,这将如何工作?我正在考虑让 PIZZA_ORDER 的主键不唯一,并且每个实际订单都有 x 条记录。但我不确定那将如何工作。再次感谢你们提供的任何信息。

最佳答案

一个销售订单有多个销售订单行项目

create table orders (
id int primary key,
...
);

create table order_items (
order_id int references orders(id),
line int,
pizza_id int references pizza(id),
...
primary key (order_id, line)
);

请参阅https://dba.stackexchange.com/questions/12991/ready-to-use-database-models-example/23831#23831节省时间:)

关于mysql - 外键关系没有意义,有没有更好的方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30606185/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com