现在的位置: 首页 > 综合 > 正文

ADO.NET Entity FrameWork 属性类型映射到自定义枚举

2012年07月19日 ⁄ 综合 ⁄ 共 1466字 ⁄ 字号 评论关闭

   我们在 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
}
}

 

 

调用结果:

 

抱歉!评论已关闭.