在我的数据库中,有一个大的"代码"表,其中包含查找整个系统中使用的值的系统代码。像这样:
[TableName("code_entries")] public class Code {
[MapField("code_nbr")][PrimaryKey, Identity] public int Id;
[MapField("code")] public string Value;
}
我是BLToolkit的新手,我希望有一个类似于我所见过的静态映射的概念,但这将允许我轻松地将这些代码在其他表中的出现映射到它们各自的值。例如:
[TableName("person")] public class Person {
[MapField("person_nbr")][PrimaryKey, Identity] public int Id;
[MapField("dob")][Nullable] public int BirthDate;
[MapField("eye_color")][Nullable] public int EyeColorCode;
[MapField("hair_color")][Nullable] public int HairColorCode;
}
如果上面的EyeColorCode和HairColorCode映射到Codes表中的值,我可以创建一个简单的方法来映射OR类中的数据并在单个查询中获得整个对象吗?
我想以这样的结尾:
// person.Id = 1
// person.DOB = some date
// person.EyeColor = "Blue"
// person.HairColor = "Brown"
谢谢David。我采用了你的方法,但稍微修改了一下,让我觉得不那么痛苦。我将关联添加到我的类中,如您的示例:
[Association(ThisKey = "EyeColorCode", OtherKey = "Id")] public Code EyeColor { get; set; }
[Association(ThisKey = "HairColorCode", OtherKey = "Id")] public Code HairColor { get; set; }
然后我写了一个扩展方法。它接受一个新对象,并将所有可写属性合并到源对象中。使用这个,我不需要在查询中指定每个属性,例如:
from p in db.Person
select p.PropertyUnion(new Person() {
{
EyeColor = p.EyeColor,
HairColor = p.HairColor
};
这为我的一些更复杂的对象节省了相当多的代码,我认为它更具可读性。下面是扩展方法的代码:
/// <summary>
/// Union by retrieving all non-null properties from source parameter and setting those properties on the instance object
/// </summary>
public static T PropertyUnion<T>(this T destination, T source) {
// Don't copy from a null object
if (Object.ReferenceEquals(source, null) || Object.ReferenceEquals(destination, null)) {
return destination;
}
// copy properties
foreach (var property in source.GetType().GetProperties()) {
if (!property.CanWrite || !property.CanRead)
continue;
var match = destination.GetType().GetProperty(property.Name);
if (!match.CanWrite || !match.CanRead)
throw new MethodAccessException("Matching property '" + match.Name + "' must allow both read and write operations.");
var value = property.GetValue(source, null);
if (value != null && !value.Equals(Activator.CreateInstance(property.PropertyType)))
match.SetValue(destination, value, null);
}
return destination;
}
再次感谢您的帮助!
这不是你真正想要的但是你可以使用Associations
所以你可以把它添加到你的Person类
[Association(ThisKey="eye_color", OtherKey="code_nbr", CanBeNull=true)]
public Code EyeColor;
[Association(ThisKey="hair_color", OtherKey="code_nbr", CanBeNull=true)]
public Code HairColor;
然后输入
from p in db.Person
select new
{
Id = p.Id,
DOB = p.BirthDate,
EyeColor = p.EyeColor.Value,
HairColor = p.HairColor.Value
};
无论如何,这些代码看起来几乎永远不会改变我通常在启动时将这些放在客户端上,然后在我显示数据时填写描述,使一切变得容易得多,如果我找不到Id,那么我只是刷新集合