And*_*son 3 c# nhibernate nhibernate-mapping
我正在构建一个针对遗留数据库的应用程序,该数据库将查找值存储在通用表中(实际上它存放在四个不同的表中.)这意味着实体表存储查找值的"id",元数据表保存"描述"这个值.
元数据表分解如下:
要获取查找描述,请加入所有四个表并指定表名,列名和查找ID.查找描述信息表包含两列 - 一列用于文本值,一列用于数值.
我想为每个查找类型设置一个单独的类(例如,我的Widget类将基于Widget.WidgetTypeId值与"WidgetType"具有多对一关系.)有哪些策略可以实现此目的?数据模型由超过1000个RPG程序使用,因此无法更改.
我遇到了几乎与你完全相同的问题,并发现以下解决方案可行.
创建SQL视图
-- I'm guessing at the table join structure here
create view LookupView
as
select t.TableName,
ci.ColumnName,
bi.Id, --This ID column needs to be the one used as the FK from other tables
bi.*, --Or whatever columns you need
coalesce(di.TextDescription, di.NumericDescription) as Description
from TableInfo t
join ColumnInfo ci on t.Id=ci.TableId
join BusinessInfo bi on bi.Id=ci.BusinessId
join LookupDescriptionInfo di on di.id=ci.id
Run Code Online (Sandbox Code Playgroud)
创建基本查找类
public class Lookup {
public virtual string Tablename {get; set;}
public virtual string ColumnName {get; set;}
public virtual string Description {get; set;}
public virtual int Id {get; set;}
//Other BusinessInfo properties
}
Run Code Online (Sandbox Code Playgroud)
创建一个继承的LookupClass
public class ArmourLookup : Lookup{}
Run Code Online (Sandbox Code Playgroud)
在业务对象上使用ArmourLookup类.
public class HeroArmour{
//Usual properties etc....
public virtual ArmourLookup Lookup {get; set;}
}
Run Code Online (Sandbox Code Playgroud)
创建子类区分映射集
public class LookupMap : ClassMap<Lookup> {
public LookupMap(){
Id(x=>x.Id).GeneratedBy.Assigned(); //Needs to be a unique ID
Map(x=>x.Tablename);
Map(x=>x.ColumnName);
Map(x=>x.Description);
//Business Info property mappings here
Table("LookupView")
DiscriminateSubClassesOnColumn<string>("ColumnName");
ReadOnly();
}
}
public class ArmourLookupMap : SubClassMap<ArmourLookup> {
public ArmourLookupMap (){
DiscriminatorValue("ArmourColumn");
}
}
Run Code Online (Sandbox Code Playgroud)
现在,您可以轻松地为每个创建新类型的列重复子类映射.此处的问题是您无法在View中更新或插入新查找,因此您处于只读模式.
此方法使用列名作为鉴别符,因此取消了表名,但如果查找表中有重复的列名,则可以为每个表创建基本查找类,并在映射中指定过滤条件.
另一个可能的解决方案是使用查找表中的T4模板生成的枚举.虽然这也是一种只读方法.
您还可以将每个查找表映射为类,并使用鉴别器模式从ColumnInfo表中获取不同的类型.
public class TableInfo {
public virtual int Id {get; set;}
public virtual string Tablename {get; set;}
public IList<ColumnInfo> Columns {get; set;}
}
public class ColumnInfo {
public virtual int Id {get; set;}
public virtual TableInfo TableInfo {get; set;}
public virtual BusinessInfo BusinessInfo {get; set;}
public virtual LookupDescriptionInfo LookupDescriptionInfo {get; set;}
//Other properties
}
public class ArmourInfoColumn : ColumnInfo {
//In the mapping you would discriminate on the columnname column.
}
etc...
Run Code Online (Sandbox Code Playgroud)
如果在列信息表中有不同的列名但是不同的tableid,则可以选择区分出一些XTable类.
您还可以区分ColumnType(数字或文本)并将LookupDescription类子类化为"Description"属性使用不同的列.
如果你能提供你的表结构和一些样本值,我可以为你更多地充实这些想法.
| 归档时间: |
|
| 查看次数: |
1220 次 |
| 最近记录: |