如何使用LINQ按属性类型而不是类型名称进行查询
本文关键字:类型 查询 LINQ 何使用 属性 | 更新日期: 2023-09-27 18:28:42
我有以下DbContext
,其中每个用// This
注释标记的DbSet
都是我的GetDbSetsByType
方法的潜在目标。如何查询.Any
lambda中的实际类型,而不是类型名称?当我使用t => t is T
时,它总是失败。我认为这是因为lambda参数被声明为Type
。
public class CtsDbContext : DbContext
{
public DbSet<Gender> Genders { get; set; } // This.
public DbSet<JobLevel> JobLevels { get; set; } // This.
public DbSet<Country> Countries { get; set; } // This.
public IEnumerable<DbSet<T>> GetDbSetsByType<T>() where T : class
{
// Get one of the above DbSets based on its type.
var tName = typeof (T).Name;
var props = GetType().GetProperties()
.Where(p => p.PropertyType.IsGenericType && p.PropertyType.Name.StartsWith("DbSet"))
.Where(p => p.PropertyType.GetGenericArguments().Any(t => t.Name == tName));
return props.Select(p => (DbSet<T>)p.GetValue(this, null));
}
}
如果t
是System.Type
的一个实例,而T
是一个类型,则应该编写:
t => t == typeof(T)
代替:
t => t is T