本文介绍了实体框架:Database.ExecuteSqlCommand方法的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

所以,我有我运行一个基本的更新语句在我的MVC应用程序4。我喜欢叫它这样(SQL Server 2008 R2中,实体框架5.0):

  VAR =的RequestData requestInfo.Database.ExecuteSqlCommand(UPDATE TABLE布拉赫..);

该命令成功完成,但有时返回的RequestData 1,有时它返回2.我不能找到什么这些返回值意味着任何文件或解释。我在这里看:

http://msdn.microsoft.com/en-us/library/gg679456(v=vs.103).aspx

但是,它并没有给出任何明确的答案。

如果有人能折腾出一个链接的东西,说明这个命令的返回值,我将大大AP preciative。


解决方案

ExecuteSqlCommand will return the number of rows affected by your UPDATE statement.


Testing:

//Update ID 2
using (var context = new Test2Context())
{
    var items = context.MyTestClasses.Where(x => x.Id == 2).Count();
    var rowsAffected = context.Database.ExecuteSqlCommand("UPDATE MyTestClasses SET Name = 'Test2' WHERE Id = 2");
    Debug.WriteLine("--First Test--");
    Debug.WriteLine("items: {0}", items);
    Debug.WriteLine("rowsAffected: {0}", rowsAffected);
}

//Update all
using (var context = new Test2Context())
{
    var items = context.MyTestClasses.Count();
    var rowsAffected = context.Database.ExecuteSqlCommand("UPDATE MyTestClasses SET Name = 'Updated'");
    Debug.WriteLine("--Second Test--");
    Debug.WriteLine("items: {0}", items);
    Debug.WriteLine("rowsAffected: {0}", rowsAffected);
}

Results:

--First Test--
items: 1
rowsAffected: 1
--Second Test--
items: 3
rowsAffected: 3

这篇关于实体框架:Database.ExecuteSqlCommand方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

09-05 11:46