Entity Framework 6.0 对枚举的支持/实体添加后会有主键反回
实验
直接上代码,看结果
实体类
[Flags]
public enum FlagsEnum
{
Day = 1,
Night = 2
}
public class EntityWithEnum
{
public int ID { get; set; } public FlagsEnum ValidTime { get; set; } }
数据库上下文
public partial class CodeFirstModel : DbContext
{
public CodeFirstModel()
: base("name=CodeFirstModel")
{
} public virtual DbSet<EntityWithEnum> EntityWithEnum { get; set; }
}
Sql server LocalDb的连接字符串
<connectionStrings>
<add name="CodeFirstModel" connectionString="data source=(LocalDb)\MSSQLLocalDb;initial catalog=TestDb;integrated security=True;multipleactiveresultsets=True;application name=EntityFramework" providerName="System.Data.SqlClient" />
</connectionStrings>
主函数
static void Main(string[] args)
{
//CreateDatabaseIfNotExists
//DropCreateDatabaseIfModelChanges
//DropCreateDatabaseAlways
Database.SetInitializer(new DropCreateDatabaseIfModelChanges<CodeFirstModel>());
using (var context = new CodeFirstModel())
{
context.Database.Initialize(true);
} using(CodeFirstModel db = new CodeFirstModel())
{
EntityWithEnum entity = new EntityWithEnum() { ValidTime = FlagsEnum.Day };
db.EntityWithEnum.Add(entity); entity = new EntityWithEnum() { ValidTime = FlagsEnum.Night };
db.EntityWithEnum.Add(entity); entity = new EntityWithEnum() { ValidTime = FlagsEnum.Night| FlagsEnum.Day };
db.EntityWithEnum.Add(entity); db.SaveChanges();
Console.WriteLine("{0}:\t{1}", entity.ID, entity.ValidTime);
Console.WriteLine("-------------------"); var entitys = from e in db.EntityWithEnum
where e.ValidTime.HasFlag(FlagsEnum.Day)
select e; foreach (var item in entitys)
{
Console.WriteLine("{0}:\t{1}", item.ID, item.ValidTime);
} }
Console.ReadKey(true);
}
运行结果
结论
Entity Framework 6.0 的 LINQ 是可以直接写 枚举的 HasFlags 方法的.
Add 的实体在 数据库保存后,会将数据库生成好的主键读出来.不用再写LINQ 再查一遍了.
Entity Framework 6.0 对枚举的支持/实体添加后会有主键反回的更多相关文章
- Entity Framework 5.0
今天 VS2012 .net Framework 4.5 Entity Framework 5.0 三者共同发布了. ( EF5 Released ) 在介绍新特性之前,先与大家回顾一下EF版 ...
- 精进不休 .NET 4.5 (12) - ADO.NET Entity Framework 6.0 新特性, WCF Data Services 5.6 新特性
[索引页][源码下载] 精进不休 .NET 4.5 (12) - ADO.NET Entity Framework 6.0 新特性, WCF Data Services 5.6 新特性 作者:weba ...
- 在Entity Framework 4.0中使用 Repository 和 Unit of Work 模式
[原文地址]Using Repository and Unit of Work patterns with Entity Framework 4.0 [原文发表日期] 16 June 09 04:08 ...
- 浅析Entity Framework Core2.0的日志记录与动态查询条件
前言 Entity Framework Core 2.0更新也已经有一段时间了,园子里也有不少的文章.. 本文主要是浅析一下Entity Framework Core2.0的日志记录与动态查询条件 去 ...
- Entity Framework 6.0 Code First(转)
源自:http://www.cnblogs.com/panchunting/tag/Code%20First/ 1 Conventions 2 Custom Conventions 3 Data An ...
- Entity Framework 6.0 入门系列 第一篇
Entity Framework 6.0 入门系列 第一篇 好几年前接触过一些ef感觉不是很好用,废弃.但是 Entity Framework 6.0是经过几个版本优化过的产物,性能和功能不断完善,开 ...
- 开发 ASP.NET vNext 续篇:云优化的概念、Entity Framework 7.0、简单吞吐量压力测试
继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之后, 关于云优化和版本控制: 我本想做一下MAC和LINUX的self-ho ...
- [EF2]Sneak Preview: Persistence Ignorance and POCO in Entity Framework 4.0
http://blogs.msdn.com/b/adonet/archive/2009/05/11/sneak-preview-persistence-ignorance-and-poco-in-en ...
- Entity Framework 5.0系列之Code First数据库迁移
我们知道无论是"Database First"还是"Model First"当模型发生改变了都可以通过Visual Studio设计视图进行更新,那么对于Cod ...
随机推荐
- 在Mac上安装anaconda,在命令行中输入conda,提示不是有效命令的解决办法
原链接:https://stackoverflow.com/questions/18675907/how-to-run-conda
- macOS -- Mac系统如何通过终端使用mysql
打开终端,输入下面的命令 mysql -u root -p 如果提示输入密码,并且能直接进入,那就太棒了,下面的就不用看了,直接使用就好了 如果没有这么幸运,提示 command not found ...
- 【转】Vim自动补全插件----YouCompleteMe安装与配置
原文网址:http://www.cnblogs.com/zhongcq/p/3630047.html 使用Vim编写程序少不了使用自动补全插件,在Linux下有没有类似VS中的Visual Assis ...
- unity里面的gameobject和transform的关系
一切都是物体(gameobject),而transform是物体的一个基本属性类,包含位置,旋转,缩放,三个基本属性,两者之间可以互相转换 查找物体,建议用transform,GameObject无法 ...
- usbip install
# README for usbip-utils## Copyright (C) 2011 matt mooney <mfm@muteddisk.com># 2 ...
- 转转转---ROWNUMBER() OVER( PARTITION BY COL1 ORDER BY COL2)用法
ROWNUMBER() OVER( PARTITION BY COL1 ORDER BY COL2)用法 http://blog.csdn.net/yinshan33/article/detail ...
- 2018-2019-1 20165226《信息安全系统设计基础》 pwd命令的实现
2018-2019-1 20165226<信息安全系统设计基础> pwd命令的实现 一.学习pwd 查看pwd 得知一个嫩过去文件路径的函数--getcwd i节点值 通过ls -i -a ...
- Java-Web 用html写一个简单的用户注册界面
代码: <!doctype htpl> <html> <head> <meta charset="utf-8" /> <tit ...
- mysql connection phase(未整理)
14.2.1 初始握手初始握手从服务器发送 Initial_Handshake_Packet开始.在这之后,客户端可以选择是否通过SSL_Connection_Request_Packet发送SSL连 ...
- Y480&Y580 刷slic2.1全自动教程
由于之前时间赶,写得比较乱,现在我重新把我.安装UltraISO.2.插上一个U盘.3.用UltraISO打开setup98.img镜像4.在UltraISO的“启动”的下拉菜单里选择“写入硬盘镜像” ...