我昨天问了一个非常相似的问题,但直到今天我才意识到我接受的答案并不能解决我所有的问题。我有以下代码:
public Expression<Func<TItem, object>> SelectExpression<TItem>(string fieldName)
{
var param = Expression.Parameter(typeof(TItem), "item");
var field = Expression.Property(param, fieldName);
return Expression.Lambda<Func<TItem, object>>(field,
new ParameterExpression[] { param });
}
使用如下:
string primaryKey = _map.GetPrimaryKeys(typeof(TOriginator)).Single();
var primaryKeyExpression = SelectExpression<TOriginator>(primaryKey);
var primaryKeyResults = query.Select(primaryKeyExpression).ToList();
这使我可以从IQueryable<TUnknown>
. 问题是此代码仅适用于单个主键,我需要添加对多个 PK 的支持。
那么,有什么方法可以调整SelectExpression
上面的方法来获取IEnumerable<string>
(这是我的主键属性名称列表)并让该方法返回一个选择这些键的表达式?
即鉴于以下情况:
var knownRuntimePrimaryKeys = new string[] { "CustomerId", "OrderId" }`
我的 Select 需要执行以下操作(在运行时):
var primaryKeys = query.Select(x=> new { x.CustomerId, x.OrderId });