Entity Framework添加记录时获取自增ID值

Entity Framework在将数据插入数据库时,如果主键字段是自增标识列,会将该自增值返回给实体对象对应的属性。

比如下面添加博客随笔至数据库的示例代码:

复制代码
 
   
var blogPost = new BlogPost()
{
Author
= "csdn " ,
Title
= "程序员的家园 "
};
using (BlogDbContext context = new BlogDbContext())
{
context.BlogPosts.Add(blogPost);
context.SaveChanges();
return blogPost.ID;
}
复制代码

SaveChanges()之后,blogPost.ID的值就是数据库中对应自增标识列的值。

看一下Entity Framework生成的SQL语句:

 
   
exec sp_executesql N ' insert [dbo].[blog_Content]([Title],[Author])
values (@0, @1)
select [ID]
from [dbo].[blog_Content]
where @@ROWCOUNT > 0 and [ID] = scope_identity()
' ,
N
' @0 nvarchar(128),@1 nvarchar(128), ' , @0 = N ' 程序员的网上家园 ' , @1 = N ' 博客园 '

EF通过scope_identity()获取自增列的值,而且我们没有对BlogPost的ID属性进行任何设置,是EF智能地判断出ID就是自增标识列。

在以前没有使用Entity Framework的时代,用的是存储过程,存储过程有一堆参数,实体对象的属性值要一一对应地赋值给这些参数,执行存储过程之后,还要通过ParameterDirection.Output的参数获取自增ID的值。

但是,只要实体类中有ID属性,ef就认为数据库对应的是一定是自增标识列。当我们把博客随笔添加至数据库后,准备用这个自增ID将随笔内容添加至数据库(随笔内容存储在单独的数据库,通过ID字段与随笔进行关联,不是自增的),却出现错误提示:

 
   
Cannot insert the value NULL into column 'ID', 
table 'CNBlogsText.dbo.blog_PostBody'; column does not allow nulls.

看看EF生成的SQL语句:

 
   
exec sp_executesql N ' insert [dbo].[CNBlogsText_blog_PostBody]([Text])
values (@0)
select [ID]
from [dbo].[CNBlogsText_blog_PostBody]
where @@ROWCOUNT > 0 and [ID] = scope_identity()
' ,N ' @0 nvarchar(128) ' , @0 = N ' 帮助程序员用技术改变世界 '

不是自增列,也来个scope_identity()。

还好,EF定制灵活的特性可以让我们轻松化解这个问题,只要在BlogDbContext中添加下面的代码:

 
   
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity
< PostBody > ().Property(p => p.ID)
.HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);
}

也可以通过在实体类属性上加标记实现:

 
   
public class BlogPost
{
[DatabaseGenerated(DatabaseGeneratedOption.None)]
public int ID { get ; set ; }
}

你可能感兴趣的:(ASP.NET,MVC)