
本文讲解如何将 java 实体中 `list
在关系型数据库设计中,不能也不应在单个列中直接存储“列表”(如 itens LIST 或 JSON 数组),因为这违反第一范式(1NF),会导致查询困难、索引失效、数据冗余和完整性难以保障。正确的做法是识别出实体间的一对多关系,并拆分为独立的父子表,由子表通过外键引用父表主键。
以你提供的 Java 模型为例:
- Order(订单)拥有多个 OrderItem(订单项)→ 一对多
- OrderItem 属于一个 Order,且关联一个 Product → 两个外键
因此,SQL 建表逻辑如下:
✅ 父表 order 不需要、也不应该包含 itens 列
❌ 错误示例:itens VARCHAR(1000) 或 itens JSON(仅作临时方案,不推荐用于核心业务)
✅ 正确方案:order 表只保存自身属性,orderItem 表负责承载“列表”语义,并通过 id_order 外键回溯归属
以下是修正后的完整建表脚本(兼容 MySQL / PostgreSQL,已修复语法错误):
dmSOBC SHOP网店系统由北京时代胜腾信息技术有限公司(http://www.webzhan.com)历时6个月开发完成,本着简单实用的理念,商城在功能上摒弃了外在装饰的一些辅助功能,尽可能的精简各项模块开发,做到有用的才开发,网店V1.0.0版本开发完成后得到了很多用户的使用并获得了好评,公司立即对网店进行升级,其中包括修正客户提出的一些意见和建议,现对广大用户提供免费试用版本,如您在使用
立即学习“Java免费学习笔记(深入)”;
-- 1. 商品表(Product)
CREATE TABLE product (
id INT PRIMARY KEY AUTO_INCREMENT,
description VARCHAR(50) NOT NULL,
value NUMERIC(10,2) NOT NULL
);
-- 2. 订单表(Order)——注意:表名 'order' 是 SQL 保留字,建议改用 'orders' 或加反引号
CREATE TABLE `order` (
id INT PRIMARY KEY AUTO_INCREMENT,
id_person INT NOT NULL,
FOREIGN KEY (id_person) REFERENCES person(id)
);
-- 3. 订单项表(OrderItem)——承载 List 的物理实现
CREATE TABLE order_item (
id INT PRIMARY KEY AUTO_INCREMENT,
id_product INT NOT NULL,
quantity INT NOT NULL CHECK (quantity > 0),
id_order INT NOT NULL,
FOREIGN KEY (id_product) REFERENCES product(id),
FOREIGN KEY (id_order) REFERENCES `order`(id)
); ? 关键注意事项:
- 命名规范:order 是 SQL 保留关键字(如 ORDER BY),在 MySQL 中必须用反引号包裹(`order`),更推荐直接命名为 orders 避免歧义;
- 外键声明语法:不同数据库略有差异。MySQL 支持内联 FOREIGN KEY (...) REFERENCES ...,但更清晰、可移植的方式是显式 ADD CONSTRAINT;
- 数据完整性:为 quantity 添加 CHECK (quantity > 0) 确保业务有效性;
- 索引优化:生产环境应在 order_item.id_order 和 order_item.id_product 上建立索引,加速关联查询;
-
级联操作(可选):如需删除订单时自动清理其订单项,可添加 ON DELETE CASCADE:
FOREIGN KEY (id_order) REFERENCES `order`(id) ON DELETE CASCADE
? 总结:Java 中的 List









