-1

我不确定如何表达这个问题。基本上我的数据库中有一个表,如下所示:

 Table1
 _________
|id       |
|_________|
|services |
|_________|
|solutions|
|_________|

但在我的模型中,我试图将其映射到三个对象:

class studies
{
    public int id {get;set;}
    public List<Service> services {get;set;}
    public List<Solution> solutions {get;set;}
}

class Solution
{
    public int id {get;set;}
    public string description {get;set;}
}

class Service
{
    public int id {get;set;}
    public string description {get;set;}
}

所以我需要做的是从数据库中提取所有表数据,然后将其重新分配给我的类。我该怎么做这样的事情?我在不允许更改表结构的约束下工作,因此仅重新设计数据库不是一种选择。

4

1 回答 1

2

我会从研究对象集合中的数据库中检索数据:

class Study 
{
    public int ID {get; set;}
    public string Solutions {get; set;}
    public string Services {get; set;}
}

然后我必须遍历集合并解析解决方案和服务字符串,每个组合两个字典“解决方案”和“服务”,其中键分别是每个解决方案和服务的名称,值是关联服务的列表(对于解决方案密钥)或相关解决方案(用于服务密钥)。就像是:

var solutions = new Dictionary<string, List<string>>();
var services = new Dictionary<string, List<string>>();

不确定语法是否正确,但你明白了。在填充字典时,请确保您不会在任何特定键的解决方案/服务列表中插入重复值。

然后,查找“service1”的可用解决方案列表将类似于:

var service1Solutions = services["service1"];
于 2013-03-06T22:12:24.657 回答