mysql如何设计商品表结构_mysql电商项目入门
发布时间 - 2026-02-03 00:00:00 点击率:次商品基础字段应精简:仅保留id、name、category_id、price(DECIMAL)、cost_price、status、created_at、updated_at;规格拆至product_spec和product_sku表;图片和详情分离存储;状态管理用publish_status+published_at;删除改用is_deleted软删。
商品基础字段怎么定:别一上来就加几十个字段
商品表最怕“想太多”,比如提前加 sku_weight、warehouse_code 这类后期才用的字段。初期只保留强依赖字段:id、name、category_id、price、cost_price、status(0下架/1上架)、created_at、updated_at。其中 price 用 DECIMAL(10,2),不是 FLOAT——浮点数会导致价格计算偏差,比如 0.1 + 0.2 ≠ 0.3。
常见错误是把所有属性塞进一张表:颜色、尺寸、

product_spec 表存规格项,product_sku 表存具体 SKU,主表只管“商品本体”。
SKU 和规格怎么关联:避免用字符串拼接做组合键
很多新手用 CONCAT(color, '-', size) 当 SKU 编码,再存在 product_sku 表里当主键。问题来了:查询某颜色所有尺码时得用 LIKE 'red-%',没法走索引;改规格名还得批量更新字符串。
更稳的做法是:
-
product_spec表存独立规格项:id、spec_key(如 'color')、spec_value(如 'red') -
product_spec_value表记录商品与规格值的多对多关系:product_id、spec_value_id -
product_sku表用自增id主键,通过JSON或关联表存规格组合(推荐后者,便于约束和查询)
MySQL 5.7+ 支持 JSON_CONTAINS,但复杂查询性能差,别依赖它做核心筛选逻辑。
图片和详情怎么存:别把大字段塞进主表
product 主表里加 detail_html 或 images_json 字段,看着省事,实际会拖慢所有 SELECT * 查询,还影响备份速度和主从同步延迟。
建议分离:
- 图片地址统一存
product_image表,字段:product_id、url、sort_order、is_primary - 富文本详情存
product_detail表,用MEDIUMTEXT,按需 JOIN - 如果要用全文检索,
name和brief单独建FULLTEXT索引,别对detail_html建
另外,图片 URL 别存相对路径或本地文件路径,必须是可直接访问的绝对 URL,否则前端渲染就报 404。
状态和上下架逻辑:别只靠 status 字段硬控制
单纯用 status 字段区分“上架/下架”,上线后很快会遇到新需求:定时上架、草稿态、审核中、库存为 0 时自动下架……这时候光靠一个字段撑不住。
更可持续的设计是:
- 加
publish_status(draft/pending/published/failed)管发布流程 - 加
published_at时间戳,配合定时任务检查是否到时间自动切状态 - 库存相关下架逻辑放到应用层或触发器里判断,不要在 SELECT 商品列表时动态算
stock > 0——容易误判,尤其高并发减库存场景
还有一个隐形坑:商品删除。永远别用 DELETE FROM product,而是加 is_deleted TINYINT DEFAULT 0,否则订单、评价、日志里的外键全断,历史数据就废了。
# mysql
# html
# js
# 前端
# json
# go
# 编码
# ai
# cos
# red
# Float
# select
# 字符串
# delete
# 并发
# default
# 下架
# 上架
# 塞进
# 主键
# 看着
# 来了
# 太多
# 这类
# 要用
# 还有一个
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Android GridView 滑动条设置一直显示状态(推荐)
Laravel如何升级到最新版本?(升级指南和步骤)
Linux安全能力提升路径_长期防护思维说明【指导】
昵图网官网入口 昵图网素材平台官方入口
原生JS实现图片轮播切换效果
谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复
Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南
如何在阿里云完成域名注册与建站?
详解vue.js组件化开发实践
高性能网站服务器配置指南:安全稳定与高效建站核心方案
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】
Laravel模型事件有哪些_Laravel Model Event生命周期详解
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
零服务器AI建站解决方案:快速部署与云端平台低成本实践
Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧
Laravel Eloquent:优雅地将关联模型字段扁平化到主模型中
详解MySQL数据库的安装与密码配置
如何确保FTP站点访问权限与数据传输安全?
Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)
Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
如何用wdcp快速搭建高效网站?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
Laravel怎么清理缓存_Laravel optimize clear命令详解
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程
如何选择可靠的免备案建站服务器?
怎么用AI帮你为初创公司进行市场定位分析?
如何在VPS电脑上快速搭建网站?
Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
原生JS获取元素集合的子元素宽度实例
小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像
Laravel如何使用Blade模板引擎?(完整语法和示例)
iOS UIView常见属性方法小结
如何在Windows服务器上快速搭建网站?
Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程
如何在香港服务器上快速搭建免备案网站?
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
微信小程序 scroll-view组件实现列表页实例代码
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
如何在云指建站中生成FTP站点?
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
香港服务器建站指南:免备案优势与SEO优化技巧全解析

