2 回答

TA貢獻1803條經驗 獲得超6個贊
正如有人在評論中指出的那樣,您應該使用泛型:
cache.Set(key1, GetTableData<Student>(dbContext));
cache.Set(key2, GetTableData<Class>(dbContext));
cache.Set(key3, GetTableData<Teacher>(dbContext));
public static IEnumerable<T> GetTableData<T> (DBContext dbContext)
{
return dbContext.Set<T>();
}
為了避免為每個實體編寫相同的代碼 (cache.Set),您可以使用反射,但您的實體應該實現某種通用接口或基類。
例如,假設您的實體實現一個通用接口IEntity:
interface IEntity {}
class Student: IEntity {}
class Teacher: IEntity {}
然后你可以
1 檢索所有實現IEntity的類型:
var type = typeof(IEntity);
var types = AppDomain.CurrentDomain.GetAssemblies()
.SelectMany(s => s.GetTypes())
.Where(p => type.IsAssignableFrom(p));
2.這樣調用GetTableData方法:
MethodInfo method = GetType.GetMethod("GetTableData ");
foreach (var entityType in types)
{
MethodInfo genericMethod = method.MakeGenericMethod(entityType);
genericMethod.Invoke(this, null);
}

TA貢獻1794條經驗 獲得超7個贊
我的解決方案如下;
MethodInfo methodInfo = typeof(CacheSettings).GetMethod("GetTableData");
string[] tablesToBeCached = { "Student", "Class", "Teacher" };
object[] parameters = new object[] { myDBContextObj };
foreach(var tblToBeCached in tablesToBeCached)
{
string key = $"{tblToBeCached}";
MethodInfo getTableDataMethod = methodInfo.MakeGenericMethod(Type.GetType($"Namespace.{tblToBeCached}, AssemblyName"));
cache.Set(key, getTableDataMethod.Invoke(null, parameters));
}
and the GetTableData() method is just one liner (Happy days ??)
public static IEnumerable<T> GetTableData<T>(MyDBContext dbContext) where T : class
{
return dbContext.Set<T>();
}
- 2 回答
- 0 關注
- 200 瀏覽
添加回答
舉報