青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Javen-Studio 咖啡小屋

http://javenstudio.org - C++ Java 分布式 搜索引擎
Naven's Research Laboratory - Thinking of Life, Imagination of Future

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  24 隨筆 :: 57 文章 :: 170 評論 :: 4 Trackbacks

6           SQL集成(SQL Integration

.NET 語言級集成查詢可以用來直接查詢關系型的數據存儲(relational data stores),而不用離開本地編程語言(local programming language)的語法或編譯時環境(the syntax or compile-time environment)。這個技巧(This facility),代碼名叫 DLinqcode-named DLinq),把 SQL schema 信息的集成(the integration of SQL schema information)的優勢帶入了(takes advantage of CLR 元數據(metadata)。這個集成(integration)把 SQL 表(table)和視圖(view)的定義編譯進 CLR 類型,這樣能夠從任何語言上訪問。

 

DLinq 定義了兩個核心的屬性(two core attributes),[Table] [Column],它們指出(indicate)了哪個 CLR 類型和屬性(which CLR types and properties)是符合(correspond to)外部的 SQL 數據(external SQL data)。[Table] 屬性能被應用于(applied to)一個類并聯合(associates CLR 類型和一個指定的(named SQL 表或視圖。這兩個屬性都是參數化的(parameterized),以允許 SQL 型的元數據(SQL-specific metadata)得以保留(retained)。舉例來說,考察下面這段 SQL schema 的定義:

 

create table People (
    Name nvarchar(
32primary key not null
    Age 
int not null
    CanCode bit not 
null
)

create table Orders (
    OrderID nvarchar(
32primary key not null
    Customer nvarchar(
32) not null
    Amount 
int
)

 

與之對等(equivalent)的 CLR 定義看起來如下:

 

[Table(Name="People")]
public class Person {
  [Column(DbType
="nvarchar(32) not null", Id=true)]
  
public string Name; 

  [Column]
  
public int Age;

  [Column]
  
public bool CanCode;
}


[Table(Name
="Orders")]
public class Order {
  [Column(DbType
="nvarchar(32) not null", Id=true)]
  
public string OrderID; 

  [Column(DbType
="nvarchar(32) not null")]        
  
public string Customer; 

  [Column]
  
public int? Amount; 
}

 

通過這個例子注意到,允許為 null nullable)的 column 映射到(map toCLR 里的允許為 null 的類型(允許為 null 的類型首次出現在 .NET Framework version 2),對 SQL 類型來說沒有一個與之一一對應的(a 1:1 correspondence withCLR 類型(比如nvarchar, char, text),原始的 SQL 類型在 CLR metadata 里被保留。

 

為發行一個查詢而不是一個關系型存儲(issue a query against a relational store),LINQ 模式的 Dlinq 實現把查詢從它的表達樹(expression tree)轉換并編成(translates …form into)一個 SQL 表達試和適合遠程賦值(suitable for remote evaluation)的 ADO.NET DbCommand 對象。例于考察如下簡單的查詢:

 

// establish a query context over ADO.NET sql connection
DataContext context = new DataContext(
     
"Initial Catalog=petdb;Integrated Security=sspi");

// grab variables that represent the remote tables that 
// correspond to the Person and Order CLR types
Table<Person> custs = context.GetTable<Person>();
Table
<Order> orders   = context.GetTable<Order>();

// build the query
var query = from c in custs, o in orders
            where o.Customer 
== c.Name
            select 
new 
                       c.Name, 
                       o.OrderID,
                       o.Amount,
                       c.Age
            }


// execute the query
foreach (var item in query) 
    Console.WriteLine(
"{0} {1} {2} {3}"
                      item.Name, item.OrderID, 
                      item.Amount, item.Age);

 

DataContext 類型提供了一個輕量級的轉換器(lightweight translator),它的工作是把標準查詢操作符(standard query operators)轉換成 SQL。DataContext 使用現有的 ADO.NET IdbConnection 來訪問存儲(accessing the store),能夠使用一個確定(established)的ADO.NET 連接對象或者一個可以用來創建一個連接的連接字符串(a connection string)的任一個來初始化(initialized)。

 

GetTable 方法提供 IEnumerable 兼容的變量(IEnumerable-compatible variables),能夠被用在查詢表達式(query expressions)里來代表(represent)遠程的表或視圖(the remote table or view)。調用 GetTable 不會導致任何與數據庫的交互(interaction),更準確的說(rather)它們扮演(representthe potential 通過時用查詢表達式來與遠程的表或視圖相配合(interact with)。在我們上面的例子中,查詢不會對存儲(store)發送傳輸的影響(get transmitted to),直到程序迭代出(iterates over)查詢表達式為止,在 C# 中使用 foreach 語句也是如此(in this case)。當程序開始迭代完成(iterates over)查詢時,DataContext 機構(machinery)把查詢表達式樹(expression tree)轉換成要發送給存儲(sent to the store)的如下所示的 SQL 語句:

 

SELECT [t0].[Age], [t1].[Amount], 
       [t0].[Name], [t1].[OrderID]
FROM [Customers] AS [t0], [Orders] AS [t1]
WHERE [t1].[Customer] 
= [t0].[Name]

 

需要重點注意的是通過在本地編程語言(local programming language)中直接(directly)內建查詢能力(building query capability),開發人員可以獲得關系模型(the relational model)的完全能力(full power),而不用不得不靜態地(statically)將關聯烘烤進(bake the relationships intoCLR 類型中。成熟的 O/R 映射(Full-blown object/relational mapping)技術還能夠為那些希望它泛函性(functionality)的用戶利用(take advantage of)這個核心查詢能力(core query capability)。

 

 

 

 

 

待續, 錯誤難免,請批評指正,譯者Naven 2005-10-24

posted on 2005-10-30 19:50 Javen-Studio 閱讀(613) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美午夜精品伦理| 99精品视频免费在线观看| 在线看国产日韩| 久久综合综合久久综合| 女女同性女同一区二区三区91| 精品动漫3d一区二区三区免费版| 久久免费精品日本久久中文字幕| 亚洲国产mv| 一区二区日本视频| 国产日韩精品久久久| 久久精品欧美日韩| 亚洲高清影视| 亚洲欧美日韩综合国产aⅴ| 国产一区二区精品久久91| 免费人成网站在线观看欧美高清| 最近看过的日韩成人| 亚洲欧美一区二区激情| 国产婷婷一区二区| 久久一区免费| 一区二区久久| 免费一级欧美在线大片| 亚洲精品欧美精品| 国产乱码精品一区二区三区av| 久久久91精品国产一区二区三区 | 亚洲黄色免费| 欧美一区二区精品久久911| 韩日欧美一区二区三区| 欧美日本簧片| 久久超碰97中文字幕| 亚洲日韩欧美视频| 欧美影院在线播放| 日韩一级免费| 国内精品**久久毛片app| 欧美另类亚洲| 久久在线91| 亚洲免费视频网站| 亚洲大胆女人| 久久视频在线看| 亚洲一区一卡| 1769国内精品视频在线播放| 欧美色网在线| 免费亚洲一区| 欧美一区二区高清在线观看| 亚洲乱码国产乱码精品精天堂 | 亚洲精品一二| 牛牛国产精品| 欧美亚洲免费在线| 亚洲视频免费看| 亚洲区在线播放| 黄色免费成人| 国产日韩欧美三区| 国产精品影片在线观看| 欧美片在线播放| 久久蜜桃资源一区二区老牛| 亚洲欧美制服另类日韩| 亚洲精品国久久99热| 欧美激情中文字幕乱码免费| 久久人91精品久久久久久不卡| 欧美一级播放| 亚洲欧美在线x视频| 这里只有视频精品| 一区二区精品在线观看| 亚洲精品女av网站| 亚洲乱亚洲高清| 亚洲免费观看高清完整版在线观看熊| 在线精品福利| 亚洲二区免费| 91久久精品www人人做人人爽| 伊人久久综合97精品| 激情视频一区二区| 悠悠资源网亚洲青| 亚洲大片一区二区三区| 在线观看日韩www视频免费| 国产主播在线一区| 国产精品一区2区| 国产精品国产三级欧美二区 | 日韩视频永久免费观看| 亚洲电影免费在线| 尤物网精品视频| 国内免费精品永久在线视频| 欧美二区在线| 欧美三级电影精品| 欧美日韩精品一区二区| 欧美激情区在线播放| 欧美a级一区二区| 免费看成人av| 欧美极品一区| 欧美区日韩区| 欧美午夜精品久久久久久人妖 | 久久人人爽国产| 久久久99国产精品免费| 久久精品视频在线观看| 久久精品国产亚洲一区二区三区| 欧美一二三区精品| 午夜亚洲激情| 蜜臀av性久久久久蜜臀aⅴ| 久久亚洲美女| 欧美大片一区| 最近中文字幕mv在线一区二区三区四区| 欧美激情中文不卡| 亚洲国产第一页| 日韩午夜精品| 亚洲香蕉视频| 亚洲国产小视频在线观看| 亚洲人成网站在线播| 9色国产精品| 亚洲免费视频在线观看| 一区二区三区高清不卡| 亚洲欧美综合国产精品一区| 久久狠狠婷婷| 欧美激情一区二区在线| 欧美三级小说| 国产一区二区三区四区| 亚洲欧洲综合另类在线| 亚洲欧美日韩中文视频| 久久综合久色欧美综合狠狠 | 欧美高清视频一区二区| 亚洲高清激情| 亚洲天堂av在线免费观看| 欧美一区二区三区免费观看视频| 久久久久国产一区二区| 欧美精品一区二区在线观看| 国产精品久久久久三级| 黄色免费成人| 亚洲性xxxx| 久热成人在线视频| 亚洲精品在线免费观看视频| 亚洲在线观看视频网站| 老妇喷水一区二区三区| 国产日韩欧美精品在线| 亚洲精品乱码久久久久久按摩观 | 亚洲欧美在线视频观看| 麻豆av一区二区三区| 日韩视频在线观看一区二区| 羞羞漫画18久久大片| 久久亚洲欧美国产精品乐播| 国产欧美精品在线播放| 亚洲精品一区二区三| 日韩视频精品在线| 欧美一级视频| 亚洲韩国青草视频| 欧美一区成人| 欧美日韩亚洲一区二区三区在线观看| 伊人成综合网伊人222| 亚洲欧美日韩在线综合| 亚洲欧洲一区二区三区在线观看| 午夜精品久久久久久久久久久久 | 在线观看91精品国产麻豆| 一二美女精品欧洲| 老司机久久99久久精品播放免费 | 亚洲国产精品传媒在线观看| 亚洲伊人观看| 欧美a级在线| 国内精品视频在线播放| 午夜欧美电影在线观看| 亚洲精品一二三区| 午夜精品www| 欧美视频免费在线观看| 亚洲激情自拍| 免费观看日韩av| 亚洲欧美乱综合| 国产精品国产三级国产专区53| 亚洲人线精品午夜| 免费不卡欧美自拍视频| 亚洲欧美日韩精品久久久| 欧美视频你懂的| 99riav国产精品| 亚洲经典在线| 麻豆av一区二区三区久久| 亚洲国产高清视频| 男人的天堂亚洲| 久久综合免费视频影院| 国产午夜亚洲精品理论片色戒| 午夜精品久久久久| 夜夜爽99久久国产综合精品女不卡| 两个人的视频www国产精品| 极品日韩久久| 免费国产自线拍一欧美视频| 欧美一区午夜精品| 国产在线观看91精品一区| 亚洲主播在线| 久久激五月天综合精品| 狠狠色丁香婷婷综合| 久久躁日日躁aaaaxxxx| 欧美一级片久久久久久久| 国产亚洲人成a一在线v站| 久久精品国产综合| 久久精品99国产精品日本| 国产欧美日韩视频在线观看| 久久激情婷婷| 久久国内精品自在自线400部| 伊人久久亚洲美女图片| 欧美在线视频观看| 亚洲一区久久久| 国产亚洲精品久| 久久国产精品久久久久久| 一本色道久久综合| 国产精自产拍久久久久久| 久久―日本道色综合久久| 久久这里有精品视频|