ASP.NETCore3.1/EFCore-Searchtablecolumnbystringname
创始人
2024-09-17 09:00:59
0

在ASP.NET Core 3.1 / EF Core中,可以使用反射来根据表列的字符串名称来搜索列。 首先需要将TableName和ColumnName作为参数传递给方法,其中TableName是要搜索的实体的名称,而ColumnName是要搜索的列名称。

以下是一个示例方法,该方法使用反射来搜索给定实体的特定列:

public static async Task> SearchByColumnName(string columnName, string value) where T : class
{
    using (var db = new DbContext())
    {
        var table = db.Set();
        var parameter = Expression.Parameter(typeof(T), "x");
        var property = Expression.Property(parameter, columnName);
        var equals = Expression.Equal(property, Expression.Constant(value));
        var lambda = Expression.Lambda>(equals, parameter);
        return await table.Where(lambda).ToListAsync();
    }
}

此方法接受 T 类型的泛型和 columnName 以及 value 两个字符串参数。它根据参数 T 推断实体的类型,然后从 DbContext 中获取实体集。 接下来,我们使用表达式树构建了一个lambda表达式,该表达式在给定的columnName 上执行的比较操作,并将结果作为值等于给定value 的布尔表达式返回。最后,我们将lambda表达式应用于实体集中的列。

这是如何使用上面的方法:

var results = await SearchByColumnName("Name", "John");

这将搜索 Customer 实体中名为 Name 的列中是否存在值为“John”的行,然后将结果作为 Customer 实例的 List 返回。

相关内容

热门资讯

wepoke模拟器!gg扑克发... wepoke模拟器!gg扑克发牌好假,(Wpk)本来是有挂(详细辅助解说技巧);支持多人共享记分板与...
透视肯定(wepoke确实有挂... 透视肯定(wepoke确实有挂)fishpoker大菠萝外挂(详细辅助透明教程)原本有挂1)wepo...
微扑克ai机器人!wepoke... 微扑克ai机器人!wepoke软件透明挂,(wepOke)从来存在有挂(详细透视wpk教程)是一款可...
透视智能ai(wepokeai... 透视智能ai(wepokeai机器人)微扑克有挂(详细辅助扑克教程)都是是真的有挂,您好,wepok...
wepoke一定有挂!wepo... wepoke一定有挂!wepoke辅助机器人,(AAPoKER)一直有挂(详细透视辅助教程)科技教程...
透视好友房(wepoke真的有... 透视好友房(wepoke真的有挂)德扑ai智能机器人线上代打(详细辅助科技教程)好像是有挂是一款可以...
透视代打(微扑克游戏辅助器)w... 透视代打(微扑克游戏辅助器)wpk ai(详细辅助力荐教程)真是真的是有挂是一款可以让一直输的玩家,...
wepoke辅助技巧!德州之星... wepoke辅助技巧!德州之星辅助透视,(aapokEr)果然真的是有挂(详细辅助实用技巧);《WP...
透视模拟器(WePoKe透明挂... 透视模拟器(WePoKe透明挂)微扑克辅助钻石(详细辅助2025新版总结)总是是有挂1)WePoKe...
微扑克全自动机器人!wepok... 微扑克全自动机器人!wepoke ai,(wEPOKE)本然是有挂(详细透视插件教程)1、点击下载安...