Octopus系列之关于多选属性如何在OO中表示呢?
在电子商务系统中 关于产品属性的问题
会设计如下几个表
产品信息 Product
选项信息表 Option 存储 Size Color....
选项值信息表 OptionValue 存储每个选项的值信息 比如 X,XL;red blue 等值信息
选项--选项值信息表 OptionToValue 存储选项和选项值之间的关系【一对多的关系】
产品属性信息表 将产品ID 选项ID 选项值ID 关联起来 ProductAttribute
下面贴出几个表的信息
CREATE TABLE [Product]
(
,) NOT NULL,
Name
--当然我简写了
)
CREATE TABLE [Option]
(
,) NOT NULL,
) NOT NULL DEFAULT (''),
))
)
CREATE TABLE [OptionValue]
(
,) NOT NULL,
) NOT NULL DEFAULT (''),
))
)
CREATE TABLE [OptionToValue]
(
,) NOT NULL,
)),
))
)
CREATE TABLE [ProductAttribute]
(
,) NOT NULL,
)),
)),
)),
))
)
现在我在程序中 使用这几个东西
关系也是明确的
选项--选项值 一对多
产品--选项 一对多
好创建系统中的VO 对象
先来创建 选项 ---选项值 Option类维护一个List<OptionValueInfo> Values 的一个引用 完成一对多关系的维护
public class OptionInfo : EntityInfo
{
public int OptionID { get; set; }
public string Name { get; set; }
public int SortOrder { get; set; }
public List<OptionValueInfo> Values
{
get
{
return OptionManager.GetOptionValueList(OptionID);
}
}
}
public class OptionValueInfo : EntityInfo
{
public int OptionValueID { get; set; }
public string Value { get; set; }
public int SortOrder { get; set; }
}
产品--选项
我通过产品ID 查询该产品的多个选项【也叫做属性】 通过 List<OptionInfo> Attributes 来维护引用关系
查询SQL语句如下
select * from [Option] where OptionID in ()
实现
public List<OptionInfo> GetOptionList(int productID)
{
string cmdText = "select * from [Option] where OptionID in ";
cmdText += "(select distinct OptionID from ProductAttribute where ProductAttribute.ProductID=@ProductID)";
SqlParameter[] parms = { SQLHelper.MakeInParam(, productID) };
return DbEntityHelper.DataReaderToEntities<OptionInfo>(SQLHelper.ExecuteReader(cmdText, parms));
}
public class ProductInfo : EntityInfo
{
private string _code;
private CurrencyInfo _currencyInfo;
public ProductInfo()
{
this._code = Utils.GetCookie(OCKeys.COOKIE_CURRENCY);
if (!string.IsNullOrEmpty(_code))
{
_currencyInfo = CurrencyManager.GetCurrencyByCode(_code);
//这样获取有问题 因为CurrencyInfo构造器并没有任何的初始化 应该再次读取一次
//if (_currencyInfo == null)
//{
// this._currencyInfo = new CurrencyInfo();
//}
}
}
#region 基础属性
public int ProductID { get; set; }
public string Name { get; set; }
public int CategoryID { get; set; }
public decimal Price { get; set; }
public decimal SingleDiscount { get; set; }
public decimal GroupDiscount { get; set; }
public int Status { get; set; }
public int CustomAttribute { get; set; }
public List<OptionInfo> Attributes
{
get
{
return OptionManager.GetOptionList(ProductID);
}
}
}
呵呵 说了这么多 好像有点罗嗦对吧 还没有说问题呢
产品的多选属性说完了,下面说说一个业务上的问题
"属性价格" 就是属性影响产品的价格 这个在 开源电子商务程序 zencart中有设计
比如我卖一双鞋子,鞋子有红色和黑色,当我选择红色时,我希望多收取5美金 ,黑色时,收取10美金
还有如果卖内存条,4G和8G的属性 将会收取不同的属性价格
还有如果卖球衣,球衣有一个 “球衣号码”的多选属性,我希望在客户在购买的时候,他可以自己输入自己想要的球衣号码,这个时候属性要求设置为
不同号码的球衣将会加收不同美金
上面是这个需求,下面我们看设计
使用 options_values_price 表示要加收的属性价格;使用price_prefix表示价格前缀“+”--表示加收几美金;“-”表示少收取几美金
那么我们将属性价格这个字段,放在那个表呢?
显然这个好像不应该放在OptionValue表中,因为同一个属性值在不同产品上设置的属性价格 是不同的
比如产品A和产品B -A产品的属性红色款 加收5$, B产品的属性红色款 加收10美金,如果将options_values_price 放在OptionValue中那么就是就是同一个价格了
看了zencart的设计,options_values_price 放在了products_attributes表中,也就说属性价格 是属于产品 属性 属性值 之间关系的描述 是一个关系属性【不知道说的对不对
,大神勿喷】
那么这个时候我在创建VO对象的时候 该怎么表示 options_values_price 这个属性呢?
前面有了 产品类Product 属性类Option 属性值类OptionValue 之间的关系也是清楚的
那么options_values_price 该怎么表示出来了呢?
Octopus系列之关于多选属性如何在OO中表示呢?的更多相关文章
- MVC之前的那点事儿系列(9):MVC如何在Pipeline中接管请求的?
文章内容 上个章节我们讲到了,可以在HttpModules初始化之前动态添加Route的方式来自定义自己的HttpHandler,最终接管请求的,那MVC是这么实现的么?本章节我们就来分析一下相关的M ...
- WebPack系列:Webpack编译的代码如何在tomcat中使用时静态资源路径不对的问题如何解决
问题: 使用webpack+vue做前端,使用tomcat提供api,然后npm run build之后需要将编译,生成如下文件: | index.html \---appserver ...
- Octopus系列之各个页面调用示例
调用首页产品 可选参数如下 New = 1, Hot = 2, Best = 3, Special = 4, Featured = 5, Other = 6 #foreach($item in $oc ...
- WPF基础到企业应用系列7——深入剖析依赖属性(WPF/Silverlight核心)
一. 摘要 首先圣殿骑士非常高兴这个系列能得到大家的关注和支持.这个系列从七月份開始到如今才第七篇,上一篇公布是在8月2日,掐指一算有二十多天没有继续更新了,最主要原因一来是想把它写好,二来是由于近期 ...
- Octopus系列之各个页面调用示例2
判断登陆的调用 #if(${islogin}) <span> ${Oct_Welcome} or <a href="${siteurl}customer/logout/&q ...
- Octopus系列之数据上传格式要求说明
各个数据列要求 价格列:字符串类型[美元价格] 产品名字:可以支持"/"等字符 分类名字:去空格处理 不得包含"&"符号 主图:一定要有主图列 不为空 ...
- WPF快速入门系列(2)——深入解析依赖属性
一.引言 感觉最近都颓废了,好久没有学习写博文了,出于负罪感,今天强烈逼迫自己开始更新WPF系列.尽管最近看到一篇WPF技术是否老矣的文章,但是还是不能阻止我系统学习WPF.今天继续分享WPF中一个最 ...
- Octopus系列之如何让前台的js脚本变得灵活重用
Octopus系列如何让前台的js脚本变得灵活,重用 方式1:ajax方式 方式2:form表单方式 面向对象的脚本封装 jQuery的封装 做Web开发的少不了前台Ajax的使用, 返回true:f ...
- Octopus系列之更新历史记录
更新笔记历史 2015.2.3 更新了产品价格的计算方法 --采用了通用化的一个处理[支持各个国家货币]更新产品价格,增加两组价格:一组用来进行前台的展示:一组用来进行后台的计算更新了产品分类 ...
随机推荐
- 领域驱动设计系列文章——浅析VO、DTO、DO、PO的概念、区别和用处
本篇文章主要讨论一下我们经常会用到的一些对象:VO.DTO.DO和PO. 由于不同的项目和开发人员有不同的命名习惯,这里我首先对上述的概念进行一个简单描述,名字只是个标识,我们重点关注其概念: 概念: ...
- 细说 Request[]与Request.Params[]
http://www.cnblogs.com/fish-li/archive/2011/12/06/2278463.html
- iOS - OC iOS 开发体系
1.iOS 开发技术体系 iOS 开发技术体系图: 层级 主要框架 Cocoa Touch UIKit 等 Media Core Graphics .OpenGl ES.Core Animation ...
- Redis基础知识之————php-Redis 常用命令专题
Keys del,delete - 删除键 dump - 返回存储在指定键值的序列化版本. exists - 确定键是否存在 expire,setTimeout,pexpire - 设置键的生存时间( ...
- oracle的正则表达式
阅读目录 1.oracle(regular expression)简单介绍 2.oracle正则特殊字符 3.oracle正则字符簇 4.各种操作符的运算优先级 5.模拟测试例子 6.oracle对应 ...
- 移动端 meta
摘自http://www.cnblogs.com/shxydx/articles/2856882.html 控制显示区域各种属性: <meta content="width=dev ...
- Hbase之获取数据
import org.apache.hadoop.hbase.TableName; import org.apache.hadoop.hbase.client.*; import org.apache ...
- openmpi出现Segmentation Fault而终止运算
欢迎关注我的社交账号: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://gith ...
- AC自动机 & Fail树 专题练习
Fail树就是AC自动机建出来的Fail指针构成的树. [bzoj3172][xsy1713]单词 题意 给定一些单词,求每个单词在所有单词里面的出现次数. 分析 构建Fail树,记录每个单词最后一个 ...
- computer English
算法常用术语中英对照Data Structures 基本数据结构Dictionaries 字典PriorityQueues 堆Graph Data Structures 图Set Data Struc ...