通过与 Jira 对比,让您更全面了解 PingCode

  • 首页
  • 需求与产品管理
  • 项目管理
  • 测试与缺陷管理
  • 知识管理
  • 效能度量
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案

25人以下免费

目录

商城web项目中如何做到不同商品有不同的参数,数据库怎么关联

商城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来冗余一份数据,用于搜索。
相关文章