关于商品分类 商品表和属性表的设计

以前有这样的一个需求,不考虑像京东或者淘宝这样分类下有子分类的情况,只考虑一层分类的情况下,可以随便添加分类,可以任意给商品添加属性,而不需要更 改表的结构. 于是设计了一个这样的结构,实现还是可以实现,一直在用,但是在操作上比较麻烦,大家讨论下有没有更好的方式.

----------------------------- 以下是几个关联的对象 省去了 getter/setter 方法 ------------------
Field.java 属性
Java 代码
  1. public class Field{  
  2.    private Integer id;  
  3.    private String name; // 属性名称  
  4. }  
public class Field{    private Integer id;    private String name; // 属性名称 } 


ProductField.java 商品属性
Java 代码
  1. public class ProductField{  
  2.      private Integer id;  
  3.      private Field field; // 属性对象  
  4.       private String value; // 属性值 这里的值不管是整数 小数 还是什么类型都是用 String 类型  
  5.   
  6. }  
public class ProductField{      private Integer id;      private Field field; // 属性对象       private String value; // 属性值 这里的值不管是整数 小数 还是什么类型都是用 String 类型  } 


Product.java 商品表
Java 代码
  1. public class Product{  
  2.    private Integer id;  
  3.    private String name; //商品名称  
  4.    //根据商品 加载这个商品的所有属性 和属性值  
  5.    private Set<ProductField> productFields = new HashSet<ProductField>();//商品属性集合  
  6. }  
public class Product{    private Integer id;    private String name; //商品名称    //根据商品 加载这个商品的所有属性 和属性值    private Set<ProductField> productFields = new HashSet<ProductField>();//商品属性集合 } 


Type.java
Java 代码
  1. public class Type{  
  2.    private Integer id;  
  3.    private String name; //分类名称  
  4.    //通过类型 可以加载这个类型下的所有商品  一种类型对应多种商品  
  5.    //(暂时不考虑一种商品属于多种类型 例如手机属于电器类,也属于通讯类产品)  
  6.    private Set<Product> products = new HashSet<Product>();  
  7. }  
public class Type{    private Integer id;    private String name; //分类名称    //通过类型 可以加载这个类型下的所有商品  一种类型对应多种商品    //(暂时不考虑一种商品属于多种类型 例如手机属于电器类,也属于通讯类产品)    private Set<Product> products = new HashSet<Product>(); } 


----------------------  Hibernate 配置文件就不帖出来了,以下是由POJO和hbm配置文件生成出来的表 示例-


//表关系
Type      
id name   
1  电脑     
3  手机      
4  脑残       
        
Product
id  name  typeid
1   SONY    1(fk) 
2   DELL    1
3   韩国猪   4
4   叁欣     3

Fields   
id name  
1  颜色
2  重量
3  型号
...
ProductFields
id pdctid  fieldid   value
1  (fk)1   (fk1)1    红色
2      1        2    500g
3      2        3    XYZ
4      2        1    白色
5      3        4    1000.00

--加载的测试数据
Java 代码
  1. +++++++++ 商 品信息 ++++++++  
  2. Name:Sony  
  3. 价 格 - 2000.00  
  4. 型 号 - YY-1939  
  5. 名 称 - 锁你牌手机  
+++++++++ 商品信息 ++++++++ Name:Sony 价格 - 2000.00 型号 - YY-1939 名称 - 锁你牌手机 
href:http://www.javaeye.com/topic/616088

转载于:https://www.cnblogs.com/newstar0101/archive/2010/03/30/1700213.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/304275.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis五种数据结构

1、String这是最简单的Redis类型。如果只使用这种类型&#xff0c;Redis就像一个可持久化的Memcached服务器。2、ListRedis的List是基于双向链表实现的&#xff0c;可以支持反向查找和遍历。常用案例&#xff1a;聊天系统、社交网络中获取用户最新发表的帖子、简单的消息队列、…

es创建索引数量多了好还是少了好_Elasticsearch性能优化总结

Elasticsearch是目前大数据领域最热门的技术栈之一,经过近8年的发展,已从0.0.X版升级至6.X版本,虽然增加了很多的特性和功能,但是在主体架构上,还是没有太多的变化。下面就把我对于ES使用实践的一些经验总结一下,供大家参考;也请大家拍砖。 一、 硬件环境选择: 如果有条…

C# NUnit的安装

前言&#xff1a;NUnit是什么&#xff1f;NUnit 是一个单元测试框架&#xff0c;专门针对于.NET来写的。NUnit是xUnit家族种的第4个主打产品&#xff0c;完全由C#语言来编写&#xff0c;并且编写时充分利用了许多.NET的特性,比如反射,客户属性等等。最重要的一点是它适合于所有…

shiro单点登录原理_SSO单点登录三种情况的实现方式详解

单点登录(SSO——Single Sign On)对于我们来说已经不陌生了。对于大型系统来说使用单点登录可以减少用户很多的麻烦。就拿百度来说吧&#xff0c;百度下面有很多的子系统——百度经验、百度知道、百度文库等等&#xff0c;如果我们使用这些系统的时候&#xff0c;每一个系统都需…

[转]解决Windows 7下Windows Live Messenger(MSN) 9.0在一直停靠任务栏而不在系统栏显示的问题...

解决Windows 7下Windows Live Messenger(MSN) 9.0在一直停靠任务栏而不在系统栏显示的问题 用上Windows 7后&#xff0c;MSN一直停靠任务栏而不在系统栏显示&#xff0c;关闭窗口就会退出MSN&#xff0c;解决方法很简单。 1、退出MSN 2、点击“开始”菜单->Windows Live->…

中国癌症大数据出来了!每年126万例癌症死亡本可避免

01 中国本土大样本数据&#xff1a;癌症真的可预防&#xff01;2017年&#xff0c;由全国肿瘤登记中心副主任陈万青教授、美国癌症协会Farhad Islami教授牵头的生活方式和感染对中国癌症发病和死亡影响的研究&#xff0c;发表在Annals of Oncology上[1,2]。该研究由美国癌症研究…

NPOI 在指定单元格导入导出图片

NPOI 在指定单元格导入导出图片Intro我维护了一个 NPOI 的扩展(WeihanLi.Npoi)&#xff0c;主要用来导入导出 Excel 数据&#xff0c;最近有网友提出了导入 Excel 的时候解析图片的需求&#xff0c;于是就有了本文的探索导入Excel 时解析图片xls 和 xlsx 的 API 稍有不同&#…

android 设置folder类型,正确配置你的 Android 项目

简评&#xff1a;优秀的 Android 项目从配置开始。: )作者在这里介绍了一个 Android 项目应该有的配置&#xff0c;文中讲到的内容大家都可以运用在自己的 Android 模板项目中。gitignore当你新建 Android 项目时&#xff0c;默认会生成 gitignore 文件&#xff0c;但并没有包含…

人就是这样啊

人类自然的天性&#xff0c;是做错事只会责备别人&#xff0c;而绝不会责备自己&#xff0c;我们每个人都是如此。不要评议人&#xff0c;免得为人所评议。不要评批他们&#xff0c;我们在相同的情形下&#xff0c;也会像他们一样。林肯从苦痛的经验中知道&#xff0c;尖锐的评…

开发物体识别桌、_【课程总结】AR系统开发“秘籍”大揭秘!

导读&#xff1a;AR技术飞速发展&#xff0c;被广泛应用于游戏、医疗、旅游、电商等行业。那么对于AR系统的整体设计和应用是如何操作的呢&#xff1f;商汤泰坦公开课第006期联合“SLAM技术及应用”暑期学校与研讨会共同推出“移动增强现实系统的设计与应用案例解析”&“AR…

商业项目中最受欢迎的 7 种编程语言

【导读】&#xff1a;Semaphore 是一个国外持续集成/持续部署方案服务商。Semaphore 称自己在过去三年对其开发者用户进行调查&#xff0c;调查他们在开发商业项目时一般都使用哪些语言。这些数据基于成千上万个在 Semaphore 上进行测试和部署的项目的人。所以现在这是迄今为止…

html云雾效果,PS中怎么做像这样的云雾效果?(有图)?

回答&#xff1a;制作步骤&#xff1a;1.按【CtrlO】键打开一幅风景素材图像。2.制作云彩效果。选择Photoshop CS6工具箱中的矩形选框工具 &#xff0c;在画面中绘制选区&#xff0c;使用默认前背景色。单击“图层”面板上的“创建新图层”按钮 &#xff0c;新建“图层1”在菜单…

为or、in平反——or、in到底能不能利用索引?

先说一个笑话&#xff0c;作为开场白。俺也换换风格试一试&#xff0c;呵呵。 在以前&#xff0c;有三个书生赶考&#xff0c;在路上遇到了一个算命先生&#xff0c;于是就问算命先生&#xff1a;我们三个人赶考&#xff0c;结果如何呀&#xff1f;算命先生伸出来了一个手指头&…

iNeuOS 工业互联网操作系统,在核工业测控领域的成功应用

注&#xff1a;由于本项目涉及核工业&#xff0c;具体细节保密。1. 前言iNeuOS工业互联网操作系统iNeuOS&#xff0c;公众号&#xff1a;iNeuOS“iNeuOS工业互联操作系统”面向未来&#xff0c;公众号首秀iNeuOS工业互联网操作系统积累了10多年工业领域知识和经验&#xff0…

5 thinkpad 黑将评测_王中林院士团队黑科技:80秒,将PM 2.5降至0!把森林氧吧搬回家!...

空气负离子(NAI)被称为“空气维生素”&#xff0c;它们广泛用于室内空气净化&#xff0c;包括去除空气中的颗粒物、对挥发性有机化合物进行氧化分解和抑菌。除了从森林、瀑布和暴雨等自然来源外&#xff0c;目前还开发了基于电晕放电、热离子电子发射、光激发和勒纳效应的纳米空…

详细解读给数据挖掘新手的6个案例

1946年2月16日&#xff0c;是一个值得纪念的日子。在这一天&#xff0c;人类历史上真正意义上的第一台电子计算机诞生了&#xff0c;此后计算机便随着科技的发展以强大的生命力飞速发展着。而作为用来定义计算机程序的形式语言——编程语言也紧跟计算机其后蓬勃发展&#xff0c…

html5 获取文件属性,H5新属性--file文件读取

首先&#xff0c;body里写入一个文件输入框&#xff1a;然后在JS中获取到这个标签&#xff0c;监听它的onchang事件来读取文件(以读取文件路径为例)&#xff1a;var inp document.querySelector("#myFile");inp.onchange function () {//console.log(this.files);f…

Jquery高亮显示文本中重要的关键字

一、界面预览鼠标放到右边的Tab按钮上&#xff0c;文字透明度降低&#xff0c;同时一段文字高亮显示&#xff0c;效果如下&#xff1a;Demo地址&#xff1a;http://5thirtyone.com/sandbox/samples/fadefocus/很绚丽的效果幺&#xff01;二、实现原理将要高亮显示的文字加上<…

公众号滑动图代码_实用技巧:公众号封面图如何提取?

有好友留言说&#xff1a;经常看到很骚气的公众号封面&#xff0c;该怎么提取下载呢&#xff01;今天就告诉你&#xff0c;公众号的高清封面图如何下载&#xff01;一共有3种方法&#xff1a;01、网页代码直接下载①在浏览器打开公众号文章&#xff0c;在网页空白处鼠标右键&am…

如何使用 HttpReports 监控 .NET Core 应用程序

简介HttpReports 基于.NET Core 开发的APM监控系统&#xff0c;使用MIT开源协议&#xff0c;主要功能包括&#xff0c;统计, 分析, 可视化&#xff0c; 监控&#xff0c;追踪等&#xff0c;适合在中小项目中使用。github&#xff1a;https://github.com/dotnetcore/HttpReports…