全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

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

发布时间:2023-10-13 05:13:28
发布人:xqq

一、商城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/IISPHP 7.1 ~ 7.4MySQL 5.7Redis

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来冗余一份数据,用于搜索。
#it技术干货

相关文章

计算机前端是什么?

计算机前端是什么?

2023-10-13
Python编程中,如何使用多进程完成多任务进程有哪些注意点?

Python编程中,如何使用多进程完成多任务进程有哪些注意点?

2023-10-13
开发人员为什么需要要有组件化思维?

开发人员为什么需要要有组件化思维?

2023-10-13
安卓APP开发工具有哪些?

安卓APP开发工具有哪些?

2023-10-13

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取