【发布时间】:2021-06-11 00:15:12
【问题描述】:
我有以下数据结构:
[
{
"id": "604ab2c4a568b9181987c9eb",
"name": "Paul",
"eventDate": "2021-03-12T00:16:03.672Z",
"created": "2021-03-12T00:16:03.673Z",
"images": [
{
"id": "604ab2c3a568b9181987c603",
"name": "DSC_0",
"url": "https://picsum.photos/300/300",
"isSelected": true
},
...
]
},
{
"id": "604ab3889c5ac2289b450e3c",
"name": "Paul",
"eventDate": "2021-03-12T00:16:03.672Z",
"created": "2021-03-12T00:16:03.673Z",
"images": [
{
"id": "604ab3879c5ac2289b450a54",
"name": "DSC_0",
"url": "https://picsum.photos/300/300",
"isSelected": true
},
...
]
},
...
]
我试图通过用户 ID 和图像 ID 获取图像,但由于某种原因我不能
var filter = Builders<Client>.Filter.Eq("Id", "604ab2c4a568b9181987c9eb");
filter &= Builders<Client>.Filter.ElemMatch(u => u.Images,t => t.Id == "604ab2c3a568b9181987c603");
return _client.Find(filter).FirstOrDefault();
这将返回所有 ID 为“604ab2c4a568b9181987c9eb”的文档,但我只想接收 ID 为“604ab2c3a568b9181987c603”的图像
这里是对象的模型:
public class Client
{
[BsonId]
[BsonRepresentation(BsonType.ObjectId)]
public string Id { get; set; }
[BsonElement("name")]
public string Name { get; set; }
[BsonElement("eventDate")]
[BsonDateTimeOptions]
public DateTime EventDate { get; set; }
[BsonElement("created")]
[BsonDateTimeOptions]
public DateTime Created { get; set; }
[BsonElement("images")]
public List<Image> Images { get; set; }
}
public class Image
{
[BsonId]
[BsonRepresentation(BsonType.ObjectId)]
public string Id { get; set; }
[BsonElement("name")]
public string Name { get; set; }
[BsonElement("url")]
[DataType(DataType.ImageUrl)]
public string Url { get; set; }
[BsonElement("isSelected")]
public bool IsSelected { get; set; }
}
所以我想知道如何修复我的代码,让它只给我一张图片,或者来自我正在搜索的用户的多张图片。
最后但同样重要的是,我想知道我是否可以更改 isSelected 值,即使我使用相同的过滤器。
【问题讨论】:
-
你试过了吗? var filter = Builders
.Filter.Eq("images.Id", "604ab2c4a568b9181987c9eb"); -
@tyrion 这个过滤器返回 null...
标签: c# asp.net-mvc mongodb mongodb-.net-driver