首页 > 数据库技术 > 详细

EF 中获取 TableAttribute的值,即数据库中真实的表名

时间:2016-06-05 21:25:11      阅读:1555      评论:0      收藏:0      [点我收藏+]

 

比如EF中我定义了这样一个实体:

 

[csharp] view plain copy
 
print?
  1. [Table(Name = "MyTableName")]  
  2. public class MyClass  
  3. {  
  4. }  
    [Table(Name = "MyTableName")]
    public class MyClass
    {
    }

 

现我想获取 MyTableName,可以这样来办:


 

[csharp] view plain copy
 
print?
  1. using System.Data.Linq.Mapping;  
  2.   
  3. namespace MyEF  
  4. {  
  5.     class Program  
  6.     {  
  7.         static void Main(string[] args)  
  8.         {  
  9.             string name = typeof(MyClass).GetAttributeValue((TableAttribute ta) => ta.Name);  
  10.             Console.WriteLine(name);  
  11.   
  12.             Console.Read();  
  13.         }  
  14.     }  
  15.   
  16.     public static class AttributeExtensions  
  17.     {  
  18.         public static TValue GetAttributeValue<TAttribute, TValue>(  
  19.             this Type type,  
  20.             Func<TAttribute, TValue> valueSelector)  
  21.             where TAttribute : Attribute  
  22.         {  
  23.             var att = type.GetCustomAttributes(  
  24.                 typeof(TAttribute), true  
  25.             ).FirstOrDefault() as TAttribute;  
  26.             if (att != null)  
  27.             {  
  28.                 return valueSelector(att);  
  29.             }  
  30.             return default(TValue);  
  31.         }  
  32.     }  
  33.   
  34.     [Table(Name = "MyTableName")]  
  35.     public class MyClass  
  36.     {  
  37.     }  
  38. }  

EF 中获取 TableAttribute的值,即数据库中真实的表名

原文:http://www.cnblogs.com/lvdongjie/p/5561723.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!