我正在尝试在这里进行一些非常动态的查询 - 最好不要在运行时调用编译器。
我有一个包含LINQ表达式的字符串,例如
var s = "from a in queryable where a.Type == 1 select a";
如何从中获得最终的IQueryable或表达式?
我见过LINQPad和RavenDb都这样做,所以我确信有一种方法,我还没有找到它。
答案 0 :(得分:20)
你有一些选择:
做一些本土的事情,解析文本并构建表达式树。标准方法是使用语言解析器来解析字符串(如ANTLR)。
使用CodeDOM编译查询(不推荐用于生产环境,因为这很慢,并且每个编译生成一个程序集,如果你做了很多,它将使你的AppDomain与程序集饱和。让我强调,不要这样做路线,如果你有任何类型的音量 - 虽然这是LINQPad的作用) - http://social.msdn.microsoft.com/Forums/en-US/linqprojectgeneral/thread/6a4defd2-76f0-4865-97b7-130e4ba7b50a
使用直接发出MSIL的Mono编译器(因此每次编译没有汇编,速度更快) - Mono Compiler as a Service (MCS)
使用动态LINQ(有一些限制和限制,但基本上执行第1点中建议的并且很好,轻量级,并且只能允许某些方法调用。它解析文本查询和构建来自它的表达式树) - http://weblogs.asp.net/scottgu/archive/2008/01/07/dynamic-linq-part-1-using-the-linq-dynamic-query-library.aspx
答案 1 :(得分:0)
从“魔术字符串”转到代码对象总是涉及某种解析。在这种情况下,最好使用EditableExpression库(可从Google Code免费获得)。取你的字符串,并将其格式化为序列化一系列EditableExpressions的结果。然后,只需将其反序列化并转换为表达式树。