Entity Framework 如何在数据库值之上进行加减

diamondTears1987 2015-09-23 01:37:06
假设有个表 balance( Id,name,moeny).这样,
我们经常会用到这样的sql语句
update balance set money=money+150 where id=10
就是说在用户原有的余额之上加上150.

我们可以把money查询出来,然后加上150在赋值过去,但是在查询和赋值之间有时间差,如果对这个数据同时有很多并发操作,很可能产生,错误,所以用moeny=money+150是最保险的做法.

但是在我使用了EF之后,在不适用SqlQuery的前提下.我不知道如何生成这种效果的语句,

我查过,EF可以使用某些乐观并发的技术,解决数据并发冲突的问题,但是我还是感觉使用这种sql的效率最高.

请问EF可以实现这种对数据库的操作吗.
...全文
379 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
圣殿骑士18 2015-09-24
  • 打赏
  • 举报
回复
补充一下: DbFirst和CodeFirst本质是一样的。 DbFirst下的“设置StoreGeneratedPattern属性为Compute”,对应CodeFirst下的“增加RowVersion字段” DbFirst下的“设置属性的并发属性值为Fixed”对应CodeFirst下的“modelBuilder.Entity<Department>() .Property(p => p.RowVersion).IsConcurrencyToken();” 两个步骤,都要设置,才能使乐观并发生效
圣殿骑士18 2015-09-24
  • 打赏
  • 举报
回复
引用 4 楼 xl2031 的回复:
[quote=引用 3 楼 daixf_csdn 的回复:] EF本来就是一种离线式存储,就像DataSet的升级版。你为什么要让它做它不擅长的事情呢
https://msdn.microsoft.com/zh-cn/data/jj592904 为什么msdn的示例在我本地不好用呢,没有进入异常,是不是ef5 和ef6,的区别.[/quote] 5楼也说了,实现乐观并发需要一个识别列的设置,这和EF5还是EF6无关,而是和你使用DbFirst和CodeFirst有关。 如果你是用CodeFirst,就是如楼上讲的,要设置RowVersion,一般来说,它是数据库里的TimeStamp字段(仅sqlserver,其他数据库可能有所不同) 而对于DbFirst,则需要在模型中设置,以下是设置的要求: 乐观并发在模型中未默认开启。 要开启乐观并发,需要将实体的某个属性的并发模式属性设置为Fixed。你不必一定使用一个Timestamp字段,但你确实需要选择一个属性,而你明确的知道它在每次数据库更新时,其值都会变化。一般来说,你需要选择一个列,它的值在每次数据库更新时,都会变化,而Timestamp确实是一个较好的选择。如果你选择了其他列,那么你要确认它满足以下要求: 1)它的值在每次数据库更新时,都会变化 2)在模型中,设置实体的此属性的StoreGeneratedPattern属性为Compute。这是让EF识别此字段为数据库生成字段 3)设置属性的并发属性值为Fixed
winnowc 2015-09-23
  • 打赏
  • 举报
回复
ef 的文档写的挺烂的,那个例子里,必须是 Blog 实体上有一个这样定义的属性才行:

[Timestamp]
public byte[] RowVersion { get;set; }
它的值会在数据库更新这行数据时会被自动修改,才可以用来进行乐观并发。你可以看下这个MVC的例子,更清晰些。
diamondTears1987 2015-09-23
  • 打赏
  • 举报
回复
引用 3 楼 daixf_csdn 的回复:
EF本来就是一种离线式存储,就像DataSet的升级版。你为什么要让它做它不擅长的事情呢
https://msdn.microsoft.com/zh-cn/data/jj592904 为什么msdn的示例在我本地不好用呢,没有进入异常,是不是ef5 和ef6,的区别.
圣殿骑士18 2015-09-23
  • 打赏
  • 举报
回复
EF本来就是一种离线式存储,就像DataSet的升级版。你为什么要让它做它不擅长的事情呢
diamondTears1987 2015-09-23
  • 打赏
  • 举报
回复
引用 1 楼 wjq 的回复:
EF主要还是查询比较方便,对于这类需求,我目前的做法是写一个专门的方法截取改造EF拼成的sql再执行。活着干脆此类功能就交给存储过程或者直接执行sql完成,EF不合适做批量数据更新。
我又蒙了 https://msdn.microsoft.com/zh-cn/data/jj592904 我在看这个,msdn上,说关于乐观并发的文档 可以同样的东西,在我电脑上,根本不会出现异响 也就是说,检测不到数据冲突 什么破玩意啊
wjq 2015-09-23
  • 打赏
  • 举报
回复
EF主要还是查询比较方便,对于这类需求,我目前的做法是写一个专门的方法截取改造EF拼成的sql再执行。活着干脆此类功能就交给存储过程或者直接执行sql完成,EF不合适做批量数据更新。

17,747

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 .NET Framework
社区管理员
  • .NET Framework社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧