gpt4 book ai didi

c# - 如何查找和更新数组中的项目(数组中的对象){Accounts[x].Items[y].StatusCode = ...}

转载 作者:太空宇宙 更新时间:2023-11-03 18:27:24 25 4
gpt4 key购买 nike

我有一个简单的嵌套数组(如下)。我的目标是在 C# 中将这些项目表示为“帐户”对象,其中包含“项目”列表以及其他帐户信息。我可以在 MongoDB 中设置这个结构,但我不知道如何更新单个帐户上单个项目的 StatusCode。

{  
"Accounts":[
{
"Name":"SomeName1",
"Email":"email1@site.com",
"OwnedItems":[
{
"ItemId":55,
"StatusCode":1
},
{
"ItemId":12,
"StatusCode":2
}
]
},
{
"Name":"SomeName2",
"Email":"email2@site.com",
"OwnedItems":[
{
"ItemId":100,
"StatusCode":3
},
{
"ItemId":101,
"StatusCode":4
}
]
}
]
}

我的问题是如何通过此设置查询以查找和更新特定的 StatusCode?

基本上我想做的是以下内容。当然,以下代码实际上不会更新数据库。

public void Update_StatusCode(string accountName, int itemId, int newStatusCode)
{
var foundAccount = collection.Find(Builders<AccountSave>.Filter.Eq(acc => acc.Name, accountName)).FirstOrDefaultAsync().Result;
foreach (var item in foundAccount.OwnedItems)
{
if (item.ItemId == itemId)
item.StatusCode = newStatusCode;
}
}

编辑:澄清一下,我使用的是 2.0 驱动程序。另外,是的,我知道没有“_id”。作为示例,假设它们被正确使用。

最佳答案

可以加入条件

public async Task UpdateStatus(string accountName, int itemId, int newStatusCode)
{
var filter = Builders<Account>.Filter.And(
Builders<Account>.Filter.Where(x => x.Name == accountName),
Builders<Account>.Filter.ElemMatch(x => x.OwnedItems, x => x.ItemId == itemId));

var update = Builders<Account>.Update.Set("OwnedItems.$.StatusCode", newStatusCode);
await collection.UpdateOneAsync(filter, update);
}

关于c# - 如何查找和更新数组中的项目(数组中的对象){Accounts[x].Items[y].StatusCode = ...},我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31277679/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com