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

首页 / 常见问题 / 项目管理系统 / 商城web项目中如何做到不同商品有不同的参数,数据库怎么关联
作者:项目管理 发布时间:24-10-23 18:02 浏览量:1998
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

商城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来冗余一份数据,用于搜索。
最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台:织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

什么是技术产品经理(TPM)
01-17 09:52
如何提升产品经理的谈判技巧
01-17 09:52
产品经理常用的软件可推荐的有哪些
01-17 09:52
to B 的产品经理和 to C 的产品经理有什么差别
01-17 09:52
在金融科技领域成为产品经理的路径
01-17 09:52
怎样准备产品经理的面试
01-17 09:52
产品经理的认证有哪些
01-17 09:52
在教育科技领域,产品经理的角色和挑战
01-17 09:52
如何评价一位产品经理的能力好坏
01-17 09:52

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科技中一路大族激光科技中心909室
  • 座机:400-185-5850
  • 手机:137-1379-6908
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2024. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
数字化咨询热线
400-185-5850
申请预约演示
立即与行业专家交流