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

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

 

 

调用结果:

 

ADO.NET Entity FrameWork 属性类型映射到自定义枚举_第1张图片

你可能感兴趣的:(framework)