商城web项目中做到不同商品有不同的参数,数据库关联的方法:1、使用大宽表;2、表上增加一个json列;3、将共性的字段放在一个主表里;4、使用用主表 + 属性表等。使用大宽表就是用大宽表,每次需要一个新列就加,但总是nullable的。
一、商城web项目中做到不同商品有不同的参数,数据库关联的方法
1、使用大宽表
就是用大宽表,每次需要一个新列就加,但总是nullable的。这样不同类型的记录,代码要自己记得取哪些列。好处是编码简单;坏处是,每次都要加列,做DDL很麻烦,如果是生产库,运维上会很繁琐,而且直接看表,不太容易分清楚哪个列是给哪个类型的记录预备的,必须另外单独记录文档。
2、表上增加一个json列
表上增加一个json列(比如叫properties)每个类型数据特有的属性都塞这个json列里。在不直接支持json的db上,只能用varchar,然后业务代码自己解析这个json。如果在支持json的db上(比如mysql > 5.7.10),就稍微方便点,可以用json_extract之类的函数。此外一些ORM工具对json支持的不是很好,于是这个json到了object里就是string,需要额外处理。提一句mybatis通过挂一个type handler可以解决,还算容易。此方法的缺点是开发人员要管住json的schema,自己确保数据的合法性。
3、将共性的字段放在一个主表里
将共性的字段放在一个主表里(比如product),此外给每种类型建立一个子表(xxx_product_part)维护特有的字段。这样结构比较清晰,但是每次查询需要引入join。每次增加一种新的类型的时候也要增加对应的新表。
4、使用用主表 + 属性表
用主表 + 属性表。属性表就是一个大的kv(pid, key, value)。但问题是value的类型会很麻烦,毕竟可能需要字符串,整数,decimal,日期,时刻,enum等不同的类型。所以要不就是服务得自己搞这个解析转换工作,这时表就得定义为(pid, key, value_type, value_data);要不就是挨个类型定义一列,上层自己取(pid, key, value_int, value_varchar, value_decimal, …)。
5、每种产品直接建立新表
每种产品直接建立新表(xxx_product, yyy_product, …),但这样做对之后的运维等工作会造成很多困难,不推荐。
如果经常增加产品的类型,可能方法2或者4会比较适合,避免每次都创建新列/新表。并且会比较灵活(但管不好就会乱套)。如果产品类型增加的不是很频繁,方法1或者3会比较适合。
二、GitHub开源商城web项目推荐
1、SuperMarket
设计精良的网上商城系统,包括前端、后端、数据库、负载均衡、数据库缓存、分库分表、读写分离、全文检索、消息队列等,使用SpringCloud框架,基于Java开发。
关键技术:
- JDBC 连接 MySQL
- 可自定义使用的连接池,在 web.xml 中配置
- Servlet 完成后端注册有效性校验
- jQuery 完成前端注册有效性校验
- 主页及注册页面均为 jsp 页面
- 使用 Ajax 技术完成前端用户名校验
配置情况:
- 本地修改 hosts 文件,自定义一个域名
- 虚拟主机使用 tomcat7.0.62 托管,将上述域名新增为虚拟主机,appBase 参数填写绝对路径
- 本项目基于 IntelliJ Idea 2020.01 编写
- JAVA_HOME 环境变量配置为 set JAVA_HOME=C:\PROGRA~1\JetBrains\INTELL~1\jbr
2、litemall
litemall = Spring Boot后端 + Vue管理员前端 + 微信小程序用户前端 + Vue用户移动端。
项目架构:
技术栈:
3、CRMEB
CRMEB打通版是历经6年时间匠心之作!系统全开源可商用,包含小程序商城、H5商城、公众号商城、PC商城、App,多种分销模式、拼团、砍价、秒杀、优惠券、抽奖、积分、会员等级、小程序直播、页面DIY,前后端分离全部100%开源。方便二开,更有详细使用文档、接口文档、数据字典、二开文档/视频教程。为开发者赋能,助力企业发展、国家富强,致力于打造较受欢迎的商城项目。
系统亮点:
- 多语言:后台随时配置语言包,移动端支持多语言切换;
- 高性能:redis缓存、队列、长连接、多种云储存、支持集群部署;
- 个性UI:多种风格切换、支持DIY各种首页/专题页面;
- 前后端分离:后端TP6,管理端iviewui,移动端uniapp;
- 代码规范:遵循PSR-2命名规范、Restful标准接口、代码严格分层、注释齐全、统一错误码;
- 权限管理:内置强大灵活的权限管理,可以控制到每一个菜单;
- 开发配置:低代码增加配置、系统组合数据模块;
- 二开效率:PHP快速生成表单、内置所有事件、后台在线编辑器、代码注释齐全、完整接口文档;
- 快速上手:详细帮助文档、接口文档、数据库字典、代码注释、一键安装;
- 系统安全:系统操作日志、系统生产日志、文件校验、数据备份。
运行环境:
- Nignx/Apache/IIS
- PHP 7.1 ~ 7.4
- MySQL 5.7
- Redis
4、mall
mall项目是一套电商系统,包括前台商城系统及后台管理系统,基于SpringBoot+MyBatis实现,采用Docker容器化部署。 前台商城系统包含首页门户、商品推荐、商品搜索、商品展示、购物车、订单流程、会员中心、客户服务、帮助中心等模块。 后台管理系统包含商品管理、订单管理、会员管理、促销管理、运营管理、内容管理、统计报表、财务管理、权限管理、设置等模块。
组织结构:
mall
├── mall-common -- 工具类及通用代码
├── mall-mbg -- MyBatisGenerator生成的数据库操作代码
├── mall-security -- SpringSecurity封装公用模块
├── mall-admin -- 后台商城管理系统接口
├── mall-search -- 基于Elasticsearch的商品搜索系统
├── mall-portal -- 前台商城系统接口
└── mall-demo -- 框架搭建时的测试代码
系统架构:
延伸阅读1:商城web项目数据库存储方案
- 公共表:提炼商品公共的信息放到数据库,例如商品id、名称、发布的商家、发布日期、上架状态。
- 扩展表:将变化的信息放到另外一个表,可以是数据库表,例如电脑商品一个表、服装一个表;也可以将信息放到MongoDB或者ElasticSearch这类文档数据库。
- 搜索组件:扩展表在全文搜索的时候不好实现,因此需要独立的组件负责搜索,可以用Elastic Search或者Solr来冗余一份数据,用于搜索。