c# – 在SQL数据库和EF6中保存标志枚举.这可能吗?
发布时间:2020-12-15 18:03:14 所属栏目:百科 来源:网络整理
导读:在ASP.NET应用程序上,我有一个标志枚举如下: [Flags]enum Target : int { None = 0,Group = 1,Student = 2,Professor = 4,All = Group | Student | Professor} 我可以使用Entity Framework 6在SQL数据库表中保存包含多个项目的值吗? 怎么会得救? 谢谢, 米
在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. 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! } 就是这样. 但不要忘记,这只适用于较新版本的.NET框架.查看EF文档中的Enum支持主题. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |