最近在用C#与数据库打交道。开发过程中采用了ORM模型(以前是纯sql玩法,复杂的逻辑用存储过程做)。
为了能通过配置文件动态地查询字段,也就是说需要能这样写:
db.AsQuery<T>.Select("字段")//伪代码
通过多方查找终于找到了方案,那就是用动态Lambda表达式树(.net3.5以后的版本支持)。
后来看别人写的ORM代码中,将C#代码转为SQL语句时出采用了表达式树,所以马上提起了学习兴趣。
先写着写一个hello world ,就是动态地拼出一个 x=>Console.WriteLine(x);
Action<String> action = x => Console.WriteLine(x);
action("hello world");
代码如下:
//参数 x => Console.WriteLine(x) 中 最前面的那个 x
var para = Expression.Parameter(typeof(String), "x");
//找到 onsole.WriteLine(String value) 这个版本
MethodInfo method = typeof(Console).GetMethod("WriteLine", new Type[] { typeof(String) });
//拼接 Console.WriteLine(x) 方法体
var call = Expression.Call(null, method, para);
//拼接成 x => Console.WriteLine(x) 格式
var lambda = Expression.Lambda<Action<String>>(call, para);
//转换成委托
var action = lambda.Compile();
action("hello world");
以下为运行的时候看到的效果
先写一个做为入门,慢慢研究。