- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先,如果标题没有意义,请允许我道歉。我很难理解我在做什么,更不用说能够使用正确的词语来描述我在做什么了。
我正在构建一个通用网格类,在其中我通过标题/linq 表达式组合定义列:
public class Column<T>
{
public string Header { get; set; }
public Func<T, string> ValueExpression { get; set; }
}
用法:
Columns = new List<Column<Employee>>
{
new Column<Employee> {Header = "Employee Id", ValueExpression = e => e.EmployeeID.ToString()},
new Column<Employee> {Header = "Name", ValueExpression = e => e.FirstName + " " + e.LastName},
new Column<Employee> {Header = "Employee Birthday Year", ValueExpression = e => e.BirthDate.HasValue ? e.BirthDate.Value.Year.ToString() : ""}
},
我想将 ValueExpression 的 ( Func<T, string>
) 转换到 IQueryable 的“员工”上:
var db = new NorthwindDataContext();
var employees = db.Employees.Select(e => e);
我可以在提取 IEnumerable<IEnumerable<string>>
时让它工作来自员工(我的观点中使用的字符串列表列表),如下所示:
var elementsList = employees.ToPagedList(PageIndex, PageSize);
var elementStringList = elementsList.ToStringList(Columns.Select(c => c.ValueExpression).ToArray());
不要介意 PagedList 的东西,它与 ToList() 无关并且有点相同;
这是 ToStringList() 扩展方法:
public static IEnumerable<IEnumerable<string>> ToStringList<T>(this IPagedList<T> enumerable, params Func<T, string>[] fields)
{
foreach (var element in enumerable)
yield return element.ToStringList(fields);
}
private static IEnumerable<string> ToStringList<T>(this T element, params Func<T, string>[] fields)
{
foreach (var field in fields)
yield return field(element);
}
问题是这种方法涉及在指定必须返回的字段之前执行 IQueryable。
因此,以下查询会在某个地方执行:
SELECT [t0].[EmployeeID], [t0].[LastName], [t0].[FirstName], [t0].[Title], [t0].[TitleOfCourtesy], [t0].[BirthDate], [t0].[HireDate], [t0].[Address], [t0].[City], [t0].[Region], [t0].[PostalCode], [t0].[Country], [t0].[HomePhone], [t0].[Extension], [t0].[Photo], [t0].[Notes], [t0].[ReportsTo], [t0].[PhotoPath]
FROM [dbo].[Employees] AS [t0]
您可能会想,从表 Employees 中检索所有字段是不希望的。
我正在寻找一种方法来以某种方式在 IQueryable 员工上构建一个扩展方法,我可以在其中传递 Func 的列表(Column 的“ValueExpression”成员)并以这种方式“构建”一个新的 IQuerable,这将执行仅从数据库中检索所需字段的 SQL。
所以我正在寻找这样的东西:
IQueryable employees = employees.SelectByExpressions(Columns.Select(c => c.ValueExpression).ToArray());
提前致谢。
最佳答案
您将遇到的基本问题是 Select 必须返回某种类型的对象,但您希望该类型具有不同的字段,具体取决于已生成的动态查询。当您使用匿名类型时,编译器会为您生成一个具有适当字段的类型。但是在您的情况下,您在编译时不知道字段列表会是什么样子,因此您无法让编译器为您生成类型。
虽然动态构建只包含所需字段的类型当然是可能的,但我不得不停下来质疑这是否有必要。使用像 LINQ-to-SQL 这样的 O/R 映射器的部分理由,特别是与数据集相反,是维护在不同时间动态返回不同字段集的代码的成本不值得您从查询中获得的少量节省或来自内存使用。事实上,在某些情况下,它甚至会使查询性能变差,因为数据库服务器无法像优化具有相同字段列表的多个查询那样优化具有不同字段列表的多个查询。
另一种选择是始终返回所有字段,但只显示选定的字段。那肯定会更简单,也更容易维护。但是,如果您已经测量了该解决方案的性能影响并确定它不满足您的要求,那么您当然可以考虑动态生成必要的类型。如果您需要有关该解决方案的帮助,我也许可以为您制作一个样本。但如果我是你,我会绝对确定在朝那个方向开始之前我需要沿着那条路走下去。
更新:这里的另一个问题是,您对这些查询的唯一目标是将它们显示在网格中,还是某种其他类型的动态绑定(bind)界面中。如果是这种情况,那么使用一种“属性包”解决方案可能会很容易,其中没有涉及特定字段的具体类型,而只是键/值对的容器,类似于 DataRow .但是,如果您尝试动态创建随后将在代码中进行操作的类型,我强烈建议您不要这样做。技术实现可能很有趣,但维护很快就会变成一场噩梦。我以前被迫维护过这样的应用程序,如果我有选择的话,我再也不会这样做了。
关于c# - 使用 Func<T, string> 委托(delegate)列表对 IQueryable 执行 .Select(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/885197/
我看了很多文章,但我仍然不清楚我们通常创建的普通委托(delegate)和多播委托(delegate)之间的区别。 public delegate void MyMethodHandler(objec
考虑以下几点: Action a1 = new Action(_insert); Action a2 = new Action(a1); a2 指的是什么?它是 a1,a1 的浅拷贝还是 a1 的深拷
我希望这听起来像是一个显而易见的问题,但是委托(delegate)返回类型是否也必须与其委托(delegate)的方法的返回类型相匹配? EG,像这样: public static void Save
我想使用 Kotlin 委托(delegate),但我不想在委托(delegate)人之外创建委托(delegate)。委托(delegate)的所有示例都如下所示: interface Worker
class SuperClass { var delegate : SuperClassDelegate? } protocol SuperClassDelegate { func d
我有一个加载 View 的 View ,需要将 View 推送到主导航 Controller 。 我已经为每个 View 设置了一个委托(delegate),并且基本上使我的调用沿着“链”返回到主导航
为简单起见,假设我想创建一个自定义 UITextField 并向其添加一个简单的行为;也就是说,如果文本字段成为第一响应者,背景颜色将变为绿色。 为此,在我的自定义类中,我必须将该类设置为委托(del
我非常有信心我应该能够使用非静态方法的委托(delegate),但下面给了我一个错误: public class TestClass { private delegate void TestD
在 C# 中不能从 System.Delegate 或 System.MulticastDelegate 继承。只要您声明标准的“运行时托管”方法,就完全可以在 MSIL 中执行此操作。但是,每次我向
我在 Storyboard 中定义了一个 iPad 界面,带有一个 SplitViewController。我想将 SplitViewController 的委托(delegate)设置为指向详细 C
我有几个解析器。有一个顶级的可以委托(delegate)给另一个。 Parser我们从 Reader 中获取他们的输入(可变)。我只想要一个 Parser为了能够一次解析,只有一个解析器应该有 Rea
一直以来我都在阅读关于反射的文章,每个人都在说:“反射很慢”,“反射很慢”。 现在我决定测试速度有多慢,令我惊讶的是,使用反射创建的委托(delegate)实际上是使用 lambda 创建的委托(de
在 Xcode 4.5 中启动了 Cocos2D 2.1 模板(没有物理引擎),针对 iOS 6 和 iPad。在 CDAudioManager.m 文件中,以下代码... AVAudioSessio
以下是来自未管理的 dll 的函数代码。它接受一个函数指针作为参数,并简单地返回被调用函数返回的值。 extern __declspec(dllexport) int _stdcall callDe
//NewCharts.h #import @interface NewCharts : UIViewController @property(nonatomic,retain)IBOutlet U
鉴于以下 MSDN 示例代码,为什么我不能定义 Action 委托(delegate)“内联”: public static void Main(string[] args) { Action
在虚幻引擎中,UFUNCTION用于通过附加说明符来丰富功能,以用于蓝图使用、复制和委托(delegate)。 然而,一些委托(delegate)类型似乎不允许绑定(bind) UFUNCTION(如
我刚刚将照片选择器放入我的项目中,一切正常。唯一的事情是它坚持在我设置委托(delegate)的地方给我以下警告 - Assigning to 'id' from incompatible type
我有一个 UIImageView 的子类,并且想将 self 作为参数传递给委托(delegate)。我在 MyImageView 之前收到错误“预期 ')'”。我需要将对象传递给委托(delegat
我正在开发 iOS 10 的语音转文本功能。 我希望调用 SFSpeechRecognitionTaskDelegate 的委托(delegate)方法来检查完成的结果。 func speechRec
我是一名优秀的程序员,十分优秀!