c# – 在SQL数据库和EF6中保存标志枚举.这可能吗?

在ASP.NET应用程序上,我有一个标志枚举如下:
[Flags]
enum Target : int {
  None = 0,Group = 1,Student = 2,Professor = 4,All = Group | Student | Professor
}

我可以使用Entity Framework 6在sql数据库表中保存包含多个项目的值吗?

怎么会得救?

谢谢,
米格尔

解决方法

为了使事情变得非常简单,可以将标志视为一个int sum(只是为了简单但实际上它们与按位运算一起工作).

因此,对于您的情况(提供枚举),如果记录有两个目标(学生和教授),最终结果将是6.

EF会存储这个. 6.
您已经告诉EF应该将此列存储为INT,因为您已经说过枚举应该被理解为int:

enum Target : int {

没有必要做任何事情(绝对没有!).

为了让这个回到学生和教授,有一个Enum.Parse,您可以手动调用(仅在需要时),但EF也将使用已经转换的属性填充该属性.

在您的代码上,您将不得不担心代码.
所以,例如,你可以这样做:

var item = new Something() { Prop = Target.Student | Target.Professor };
context.Save();

var item2 = context.GetSomething();

if (item2.Prop.HasFlag(Target.Professor) && item2.Prop.HasFlag(Target.Student))
{
   // WOW!
}

就是这样.
我在EF6上使用它,根本没有配置.
至少采用CodeFirst方法.

但不要忘记,这只适用于较新版本的.NET框架.查看EF文档中的Enum支持主题.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...