首页 > 后端开发 > C++ > 如何在LINQ查询中动态选择列?

如何在LINQ查询中动态选择列?

Susan Sarandon
发布: 2025-01-28 19:56:10
原创
982 人浏览过

How Can I Dynamically Select Columns in LINQ Queries?

LINQ中的动态列选择

当列在编译时未知时,动态选择LINQ查询中的特定列可能具有挑战性。但是,有一种解决方案涉及动态创建传递给Select的lambda表达式。

考虑以下Data类:

<code class="language-csharp">public class Data
{
    public string Field1 { get; set; }
    public string Field2 { get; set; }
    public string Field3 { get; set; }
    public string Field4 { get; set; }
    public string Field5 { get; set; }
}</code>
登录后复制

为了动态选择特定列,您可以使用CreateNewStatement方法动态创建lambda表达式:

<code class="language-csharp">private Func<Data, Data> CreateNewStatement(string fields)
{
    var xParameter = Expression.Parameter(typeof(Data), "o");
    var xNew = Expression.New(typeof(Data));

    var bindings = fields.Split(',')
        .Select(o => o.Trim())
        .Select(o =>
        {
            var mi = typeof(Data).GetProperty(o);
            var xOriginal = Expression.Property(xParameter, mi);
            return Expression.Bind(mi, xOriginal);
        });

    var xInit = Expression.MemberInit(xNew, bindings);
    var lambda = Expression.Lambda<Func<Data, Data>>(xInit, xParameter);
    return lambda.Compile();
}</code>
登录后复制

此方法将逗号分隔的字段列表作为字符串,并动态生成一个lambda表达式,该表达式使用指定的字段初始化一个新的Data对象。

然后,您可以使用CreateNewStatement方法创建lambda表达式并将其传递给Select:

<code class="language-csharp">var result = list.Select(CreateNewStatement("Field1, Field2"));</code>
登录后复制

这将返回一个具有指定字段填充的Data对象的序列。请注意,此技术适用于在编译时未知所选字段的情况。如果所选字段是静态的,则使用常规lambda表达式或基于反射的方法效率更高。

以上是如何在LINQ查询中动态选择列?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板