- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个字段,用于计算用户的订阅总数。现在我像这样更新这个字段:
using (var context = new AppDbContext())
{
var foundEntry = context.Users.Find(id);
if (foundEntry != null)
{
foundEntry.TotalSubscriptions = foundEntry.TotalSubscriptions + 1;
context.Entry(foundEntry).CurrentValues.SetValues(foundEntry);
var result = context.SaveChanges();
}
}
但是这样我必须对数据库进行 2 次查询。一个用于获取当前总数,一个用于更新值。
有没有办法只用 Entity Framework 查询一次数据库就可以做到这一点?
我想尝试这样的事情:
var user = new User() { Id = userId, TotalSubscriptions = currentS + 1 };
db.Users.Attach(user);
db.Entry(user).Property(x => x.TotalSubscriptions).IsModified = true;
但我面临的问题是我必须先获取当前计数,但不知道如何在单个查询中进行操作。我认为使用原始 SQL 语句/查询可以对此进行 1 次查询。
我正试图归档这样的东西:https://stackoverflow.com/a/2762856/1286942但有 Entity Framework 。
更新
我也试过这样的:
var user = new User() { Id = userId };
db.Users.Attach(user);
user.TotalSubscriptions = context.Entry(user)
.Property(u => u.TotalSubscriptions).OriginalValue + 1;
db.Entry(user).Property(x => x.TotalSubscriptions).IsModified = true;
但问题是 .OriginalValue
和 .OriginalValue
总是返回 0。所以 TotalSubscriptions
字段总是更新为 -1或 1.
更新 #2
现在我只看到这个作为一个选项:
var numberOfUpdatedRows = context.Database
.ExecuteSqlCommand("UPDATE dbo.Users
SET TotalSubscriptions = TotalSubscriptions + 1
WHERE id = " + id + "");
最佳答案
此类代码的基本方法是为您的 SQL 代码使用存储过程,并将变量值传递给该过程。这是您的问题的可能解决方案。
CREATE PROCEDURE AdjustSubscriptions
@userid int,
@adjustment int
AS
BEGIN
DECLARE @subs int
SET NOCOUNT ON
UPDATE UserInfo
SET @subs = currentS + @adjustment, currentS = @subs
WHERE userID = @userid
SELECT @subs AS SubscriptionCount
END
这会将 currentS 值选择到一个变量中,按照@adjustment 中指定的值对其进行调整,(添加三个订阅?传递一个三。删除三个订阅?传递一个负三)然后将值更新到保存的行.最后,返回仅包含调整后的 subscriptionCount 值的行。
可以重写存储过程以在 OUTPUT 变量中返回值(如果实现正确,您只需将值返回到变量中,而不必处理记录集),甚至可以使用 RETURN @subs 语句在程序结束时将调整后的值作为返回值返回。我强烈建议您不要使用 RETURN @subs 方法,因为它会在返回字符串或 smallint 之外的值时中断。
我留给您实现 Entity Framework 代码来处理存储过程。我不相信您可以在 Entity Framework 内使用一次调用对值进行同样的直接操作,但我非常愿意以其他方式展示。
快乐编码。
关于c# - 如何在只有一个数据库查询的情况下在计数器字段上执行 +1?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34010548/
我是 Java 新手,这是我的代码, if( a.name == b.name && a.displayname == b.displayname && a.linknam
在下面的场景中,我有一个 bool 值。根据结果,我调用完全相同的函数,唯一的区别是参数的数量。 var myBoolean = ... if (myBoolean) { retrieve
我是一名研究 C++ 的 C 开发人员: 我是否正确理解如果我抛出异常然后堆栈将展开直到找到第一个异常处理程序?是否可以在不展开的情况下在任何 throw 上打开调试器(即不离开声明它的范围或任何更高
在修复庞大代码库中的错误时,我观察到一个奇怪的情况,其中引用的动态类型从原始 Derived 类型更改为 Base 类型!我提供了最少的代码来解释问题: struct Base { // some
我正在尝试用 C# 扩展给定的代码,但由于缺乏编程经验,我有点陷入困境。 使用 Visual Studio 社区,我尝试通过控制台读出 CPU 核心温度。该代码使用开关/外壳来查找传感器的特定名称(即
这可能是一个哲学问题。 假设您正在向页面发出 AJAX 请求(这是使用 Prototype): new Ajax.Request('target.asp', { method:"post", pa
我有以下 HTML 代码,我无法在所有浏览器中正常工作: 我试图在移动到
我对 Swift 很陌生。我如何从 addPin 函数中检索注释并能够在我的 addLocation 操作 (buttonPressed) 中使用它。我正在尝试使用压力触摸在 map 上添加图钉,在两
我设置了一个详细 View ,我是否有几个 Nib 文件根据在 Root View Controller 的表中选择的项目来加载。 我发现,对于 Nibs 的类,永远不会调用 viewDidUnloa
我需要动态访问 json 文件并使用以下代码。在本例中,“bpicsel”和“temp”是变量。最终结果类似于“data[0].extit1” var title="data["+bpicsel+"]
我需要使用第三方 WCF 服务。我已经在我的证书存储中配置了所需的证书,但是在调用 WCF 服务时出现以下异常。 向 https://XXXX.com/AHSharedServices/Custome
在几个 SO 答案(1、2)中,建议如果存在冲突则不应触发 INSERT 触发器,ON CONFLICT DO NOTHING 在触发语句中。也许我理解错了,但在我的实验中似乎并非如此。 这是我的 S
如果进行修改,则会给出org.hibernate.NonUniqueObjectException。在我的 BidderBO 类(class)中 @Override @Transactional(pr
我使用 indexOf() 方法来精细地查找数组中的对象。 直到此刻我查了一些资料,发现代码应该无法正常工作。 我在reducer中尝试了上面的代码,它成功了 let tmp = state.find
假设我有以下表格: CREATE TABLE Game ( GameID INT UNSIGNED NOT NULL, GameType TINYINT UNSIGNED NOT NU
代码: Alamofire.request(URL(string: imageUrl)!).downloadProgress(closure: { (progress) in
我是一名优秀的程序员,十分优秀!