如何解决使用 Dynamic.Linq 在非通用可查询的多个属性上左连接可查询
class Entity
{
int Id { get;set; }
}
class ExtraField
{
int EntityId { get;set; }
string Key { get;set; }
string Value {get;set; }
}
产生 2 个查询
IQueryable entities;
IQueryable extraFields;
一个实体可以有多个额外的字段。并非所有实体都包含相同数量的额外字段。因此,需要左连接。可查询的最终结果应导致以下结果:
实体 ID | 额外字段 1 | 额外字段 2 | 额外字段 3 |
---|---|---|---|
1 | 价值 | 价值 | 价值 |
2 | 价值 | NULL | NULL |
3 | NULL | NULL | NULL |
在 sql 中,我想创建某种 PIVOT 来创建上面的结果。但是,我想用 linq 来实现这一点。
因为一个实体可以有 x 个额外字段,所以我需要在额外字段表上进行 x 个连接。因为该字段并不总是存在,所以我需要一个 LEFT 连接。
我在 stackoverflow 和 Dynamic Linq 文档上花了几个小时,但无法找到有关如何使用带有字符串语法的动态 linq 构建查询的答案。
我走了这么远:
entities.GroupJoin(extraFields,"Id","EntityId","new(outer.Id as Id,inner as ExtraFields)").SelectMany("ExtraFields.DefaultIfEmpty()","new( what do i need to put here?? )");
使用通用的非动态 linq,我可以正常工作。但是动态 Linq 相当于什么?
var result = from entity in entities
from extraField in extraFields.Where(ef => ef.EntityId == entity.Id && ef.Key = "ExtraField1").DefaultIfEmpty()
select new
{
EntityId = entity.Id,ExtraField = extraField.Value
};
解决方法
我猜你正在寻找如何加入。不清楚你希望看到什么
示例:
void Main()
{
var entities = new List<Entity>() { new Entity() {Id = 1}};
var extraFields = new List<ExtraField>() {
new ExtraField() {EntityId = 1,Key = "ExtraField1",Value="a"},new ExtraField() {EntityId = 1,Key = "ExtraField2",Value="b"}
};
var result = from entity in entities
from extraField in extraFields.Where(ef => ef.EntityId == entity.Id && ef.Key == "ExtraField1").DefaultIfEmpty()
select new
{
EntityId = entity.Id,ExtraField = extraField.Value
};
result.Dump("original");
entities
.GroupJoin(
extraFields,en => en.Id,ext => ext.EntityId,(en,ext) => new { entities = en,ExtraField = ext }
)
.Dump("join");
}
public class Entity
{
public int Id { get; set; }
}
public class ExtraField
{
public int EntityId { get; set; }
public string Key { get; set; }
public string Value { get; set; }
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。