C#通过Expression获取指定属性的名称

【原创】C#通过Expression获取指定属性的名称

作者寒羽枫(cityhunter172) 

大家所熟悉的是通过对象属性来访问该属性的值,或是由字符串通过反射来获取属性,并取值。今天我要说的是,通过对象的属性来获取该属性的名称,其意义在于拼接字符串时显示该名称,特别是自行拼接 SQL语句。下列代码是个简单测试类:

[csharp]  view plain copy
  1. public class TestClass  
  2.     {          
  3.         public int ID { getset; }  
  4.   
  5.         public string Name { getset; }  
  6.   
  7.         public DateTime CreateDate { getset; }  
  8. }  

1、直接访问属性值;

[csharp]  view plain copy
  1. var obj = new TestClass ();  
  2. Response.Write(obj.ID) ;  

2、由字符串获取指定的属性值。

[csharp]  view plain copy
  1. using System.Reflection;  
  2.   
  3. var obj = new TestClass ();  
  4. Response.Write(obj.GetType().GetProperty("ID").GetValue()) ;  

3、通过对象的属性反向获取该属性的名称;

[csharp]  view plain copy
  1. using System.Linq.Expressions;  
  2.         public static string GetPropertyName<T>(Expression<Func<T,object>> expr)  
  3.         {  
  4.             var rtn = "";  
  5.             if (expr.Body is UnaryExpression)  
  6.             {  
  7.                 rtn = ((MemberExpression)((UnaryExpression)expr.Body).Operand).Member.Name;  
  8.             }  
  9.             else if (expr.Body is MemberExpression)  
  10.             {  
  11.                 rtn = ((MemberExpression)expr.Body).Member.Name;  
  12.             }  
  13.             else if (expr.Body is ParameterExpression)  
  14.             {  
  15.                 rtn = ((ParameterExpression)expr.Body).Type.Name;  
  16.             }  
  17.             return rtn;  
  18.     }  
  19.   
  20. Response.Write(GetPropertyName< TestClass >(p=>p.ID)) ; //输出的是 "ID" 两字母  
  21. Response.Write(GetPropertyName< TestClass >(p=>p. Name)) ; //输出的是 "Name" 四个字母  
  22. Response.Write(GetPropertyName< TestClass >(p=>p)) ; //输出的是 "TestClass" 九个字母  

第三种常用在拼接自定义 SQL语句或是动态 SQL中,例如:

var sql = "select a.ID,a.Name from dbo.TestClass";就可以这样写了

var sql = "select a. " + GetPropertyName<TestClass>(p=>p.ID)+",a." + GetPropertyName<TestClass>(p=>p. Name)+ " from dbo." + GetPropertyName<TestClass>(p=>p);

 

寒羽枫(cityhunter172

2012-11-13 完稿 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值