0

我有一个代表矩阵的表:

CustType  DiscountGroup1 DiscountGroup2 DiscountGroup3
Wholesale        32           10               15  
Retail           10           15               0 

我所有的库存商品都有相应的折扣组代码 1、2 或 3。

在开票时,我想查找客户类型在开票项目上获得的折扣。

该表需要能够增长以包含新的客户类型和新的折扣组,因此不能硬编码。

我想我会把数据拉到一个数组中,这样我就可以按索引选择列,但我被我的实体太聪明了......

var disc = (from d in context.CustDiscountGroups
                    where d.CustType == Wholesale
                    select d).ToArray(); 

我只能按名称访问列,即:disc[0].DiscountGroup1

如果我尝试disc[0,1],我会收到一个错误,说明里面的索引数量错误。

我错过了什么?我觉得这是一个荒谬的基本问题。我唯一的另一个想法是将列命名为 1、2、3 等并构建一个 sql 选择字符串,我可以在其中使用变量来表示列名。

该数据库也处于设计阶段,因此可以以任何需要的方式重新制作表,我正在努力让我的头脑围绕哪种方式来解决问题。

4

1 回答 1

0

您的实体CustDiscountGroups具有属性 CustType, DiscountGroup1, DiscountGroup2, DiscountGroup3并且您的查询返回数组, CustDiscountGroups因此您无法访问,就像[0,1]没有二维数组一样

如果您需要访问第一个项目,您可以获取它,disc[0]然后您可以通过属性名称获取折扣组的任何属性。喜欢

disc[0].CustType, disc[0].DiscountGroup1, disc[0].DiscountGroup2, disc[0].DiscountGroup3

如果要获取数组数组,则使用反射获取属性值,如下所示

var disc = context.CustDiscountGroups.Where(c=>c.CustType == Wholesale)
             .Select(v=>typeof(CustDiscountGroups)
                         .GetFields(System.Reflection.BindingFlags.Public)
                          .Select(f=>f.GetValue(v)).ToArray())
              .ToArray();

var disc = context.CustDiscountGroups.Where(c=>c.CustType == Wholesale)
             .Select(v=>typeof(CustDiscountGroups)
                         .GetProperties()
                          .Select(f=>f.GetValue(v,null)).ToArray()).ToArray();

现在您可以访问诸如disc[0][1]

请注意:我没有编译和测试上面的代码,请理解并根据需要进行更改

于 2013-05-04T11:05:08.923 回答