我们在 LinqToSql 的时候可以很轻松的设置 模型内某一个对象的Int字段类型为用户自定义的枚举类型。
但在EF内不知为何微软没有直接提供设置方法。经过摸索后发现可以通过修改以下几处代码后完美实现EF内也可以将对象的字段类型
设置为枚举类型。
1.修改Customer 属性 CustomerType 的 public 关键字为 Private (注:此处代码均由EF自动生成,我们只要修改public键字即可)
代码
[global::System.Data.Objects.DataClasses.EdmScalarPropertyAttribute(IsNullable=false)]
[global::System.Runtime.Serialization.DataMemberAttribute()]
private int CustomerType
{
get
{
return this._CustomerType;
}
set
{
this.OnCustomerTypeChanging(value);
this.ReportPropertyChanging("CustomerType");
this._CustomerType = global::System.Data.Objects.DataClasses.StructuralObject.SetValidValue(value);
this.ReportPropertyChanged("CustomerType");
this.OnCustomerTypeChanged();
}
}
2. 手动 建立 Customer partial 类以 CustomerType_New 替代 EF生成的 CustomerType 属性
代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace EFEnum
{
public partial class Customer
{
public CustomerType CustomerType_New
{
get { return (CustomerType)CustomerType; }
set { CustomerType = (int)value; }
}
}
}
3.调用
代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace EFEnum
{
class Program
{
static void Main(string[] args)
{
using (TestEntities t = new TestEntities())
{
//调用修改后的EF模型
foreach (var u in t.Customer)
{
Console.WriteLine(string.Format("CustomerName:【{0}】 CustomerType:【{1}】", u.CustomerName, u.CustomerType_New));
}
Console.ReadKey();
}
}
}
/// <summary>
/// 映射 Customer类 CustomerType属性 为枚举
/// </summary>
public enum CustomerType
{
/// <summary>
/// 交易客户
/// </summary>
Trader,
/// <summary>
/// 供货商
/// </summary>
Supplier
}
}
调用结果:
作者:RyanDing
出处:http://www.cnblogs.com/ryanding/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。如有疑问,可以通过 ryan.d@qq.com 联系作者本人。