c# - 如何使用动态列执行 LINQ where 子句
问题描述
我正在尝试使用 System.Linq.Dynamic.Core ( https://github.com/StefH/System.Linq.Dynamic.Core ) 来创建动态查询。
按照github页面上给出的示例,我尝试了以下
lstContacts = lstContacts.Where("@0 == true", "active");
但是我得到以下结果:'active is not a valid value for Boolean
解决方案
参考这个库:
using System.Linq.Dynamic;
并像这样进行查询:
string columnName = "active";
var lstContacts = lstContacts.Where(columnName + " == true");
这是一个工作示例:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Dynamic;
public class Program
{
public static void Main()
{
var lstContacts = new List<Contact>{
new Contact{Id = 1, Active = true, Name = "Chris"},
new Contact{Id = 2, Active = true, Name = "Scott"},
new Contact{Id = 3, Active = true, Name = "Mark"},
new Contact{Id = 4, Active = false, Name = "Alan"}};
string columnName = "Active";
List<Contact> results = lstContacts.Where(String.Format("{0} == true", columnName)).ToList();
foreach (var item in results)
{
Console.WriteLine(item.Id.ToString() + " - " + item.Name.ToString());
}
}
}
public class Contact
{
public int Id
{
get;
set;
}
public bool Active
{
get;
set;
}
public string Name
{
get;
set;
}
}
您可以在此处尝试此.net-fiddle-
推荐阅读
- c# - 过渡状态 VS 开关案例什么是应用状态机的最佳方法 [C#]
- sql - 子查询返回超过 1 个值:正在执行 UDF
- javascript - 如何在 Vuex 模块(vueJs)中过滤命名空间的 getter
- algorithm - 将一个数组划分为K个子数组/组时,最大化所有子数组中的最小子数组和
- python - ValueError: int() 以 10 为基数的无效文字:'
' - c# - 逆列表二级键索引实现?
- r - r 标签变量组合
- javascript - 如何在不使用 arr.reverse() 的情况下使用当前函数反转数组?
- prestashop - 在 PrestaShop 1.7 主题中将数组元素添加到 smarty 变量
- forms - 更改两级 DropdownButtonFormField :应该只有一项具有 [DropdownButton] 的值