如何解决在 .NET 中进行源过滤后的 Elasticsearch 映射 DTO
我有一个映射到 elasticsearch 索引的 POCO String
,我想对该索引执行查询并仅返回特定字段。我创建了一个 DTO FooIndex
,它只包含我要返回的字段的属性。
如果 DTO 中的属性名称与索引映射中的名称相匹配,这会正常工作,但我希望某些属性具有不同的名称并将它们映射到索引字段。我该怎么做?
FooStatus
解决方法
我想为某些属性使用不同的名称并将它们映射到索引字段。我该怎么做?
如果要映射的属性在对象图中处于相同深度,则可以使用 DataMemberAttribute
或 PropertyNameAttribute
将字段映射到 POCO 上不同命名的属性。
如果属性处于不同的深度,这不是使用内置序列化器可以轻松完成的。您可以拥有应用了序列化程序将 JSON 字段反序列化为的属性的私有成员,以及具有所需名称的公共属性。要反序列化的对象图的整体形状需要与 FooIndex
相同,但是例如映射 FooIndex.Bar.Baz
将要求 FooStatus
的对象图深度为三层才能映射 Baz
。
要使用其他序列化程序(如 JSON.NET 和 System.Text.Json)完成此操作,需要编写自定义 JsonConverter
,依次读取每个属性并分配值。这是相当费力的工作,并且需要在 FooStatus
的属性需要更改时随时重新访问。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。