走進Linq-Linq to SQL源代碼賞析 Table的獲取過程

作者: 橫刀天笑  來源: 博客園  發布時間: 2008-09-24 12:01  閱讀: 8999 次  推薦: 0   原文鏈接   [收藏]  
 

系列文章導航:

走進Linq--Linq橫空出世篇

走進Linq-輝煌的背后

走進Linq-Linq大觀園

不能不說的C#特性-對象集合初始化器

不能不說的C#特性-匿名類型與隱式類型局部變量

不能不說的C#特性-擴展方法

不能不說的C#特性-匿名方法和Lambda表達式

不能不說的C#特性-迭代器(上)及一些研究過程中的副產品

不能不說的C#特性-迭代器(下),yield以及流的延遲計算

走進Linq-Linq to Objects(上)基礎篇

走進Linq-Linq to Objects(下)實例篇

走進Linq-Linq to SQL感性認識篇

走進Linq-Linq to SQL How do I(1)

走進Linq-Linq to SQL How do I(2)

走進Linq-Linq to SQL How do I(3)

走進Linq-How do I(4)拾遺補零篇第一節

走進Linq-Linq to SQL源代碼賞析 Table的獲取過程

走進Linq-Linq to SQL源代碼賞析之Provider的初始化

走進Linq-Linq to SQL源代碼賞析,通過Linq to SQL看Linq

 

上一篇我們看到了DataContext是如何初始化的,它需要一個連接對象,還需要一個MappingSource做映射的配置。

DataContext中我們打交道最多的也許就是GetTable<TEntity>()方法了,這個方法會獲取一個Table<TEntity>對象,今天我們就來看看這個對象是如何獲取的。

對于獲取Table<TEntity>對象我們還要看看這個DataContext是不是強類型的,關于強類型的DataContext可以看我前面一篇文章,強類型的DataContext里包含有幾個Table<TEntity>類型的屬性,比如我們的庫中有blogsposts等數據庫表,那么你可能就會建立Table<Blog>Table<Post>類型的屬性(參見前面一篇文章)。在上一章DataContext的初始化里講到Init方法的最后一行是InitTables方法的調用。我們首先來看看InitTables方法的代碼:

/// <summary>
/// 初始化數據庫中有幾個表
/// 從方法實現中意圖來看,這個方法主要在定義了強類型的DataContext才有意義
/// 在強類型的DataContext里一般定義了Table<Post>之類的字段來表示數據庫中有幾個
/// 表,該方法調用DataContext的GetTable方法設置這些字段的值
/// </summary>
/// <param name="schema"></param>
private void InitTables(object schema)
{
     
//用反射遍歷DataContext類(可能是它的子類)里所有的公有實例字段
      foreach (FieldInfo info in schema.GetType().GetFields(BindingFlags.Public |
                  BindingFlags.Instance))
     {
        
//字段類型
         Type fieldType = info.FieldType;
        
//該字段是否是泛型的,并且是Table<>類型的,而且該字段的值為null
        if ((fieldType.IsGenericType && (fieldType.GetGenericTypeDefinition() ==
            typeof(Table<>))) && (((ITable)info.GetValue(schema)) == null))
         {
              
//獲取Table<TEntity>中TEntity的具體類型
                Type type = fieldType.GetGenericArguments()[0];
              
//調用DataContext的GetTable方法得到一個ITable對象
                ITable table = this.GetTable(type);
              
//設置值
                info.SetValue(schema, table);
          }
        }
}

 

0
0
 
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()