在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! }
原文地址:https://www.jb51.cc/csharp/97382.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。