RyanDing

用编码抒写未来

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
  41 随笔 :: 0 文章 :: 1243 评论 :: 52万 阅读

   我们在 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
}
}
复制代码

 

 

调用结果:

 

posted on   ryanding  阅读(3512)  评论(2编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示