Lv.的博客

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

 

比如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. }  
posted @   Avatarx  阅读(2383)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
历史上的今天:
2015-06-05 windows下实现微秒级的延时
2014-06-05 oracle之报错:ORA-00054: 资源正忙,要求指定 NOWAIT_数据库的几种锁
2014-06-05 oracle建索引的可选项
2014-06-05 Oracle自定义函数
2014-06-05 QT 操作oracle数据库遇到的问题
2014-06-05 多线程的那点儿事(之原子锁)
2014-06-05 创建ORACLE JOB
点击右上角即可分享
微信分享提示