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

Javen-Studio 咖啡小屋

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

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

7           XML集成(XML Integration

.NET 語言級集成查詢 for XMLXLinq)允許 XML 數(shù)據(jù)能夠通過使用標(biāo)準(zhǔn)查詢操作符(standard query operators)就像樹形的操作符(tree-specific operators)一樣來查詢,它能夠提供類似 XPath 的導(dǎo)航(XPath-like navigation)在后代(descendants),祖先(ancestors)和兄弟姐妹(siblings)的XML元素中導(dǎo)航。它為 XML 提供一個(gè)有效率的內(nèi)存中的表現(xiàn)(an efficient in-memory representation),它與現(xiàn)有的(existingSystem.Xml reader/writer 的基礎(chǔ)設(shè)施(infrastructure)相結(jié)合(integrates with),它比 W3C DOM 更容易使用。有三個(gè)類型在集成 XML 和查詢中(integrating XML with queries)做了大部分工作:XNameXElement XAttribute。

 

XName 提供一個(gè)有用的途徑來(an easy to use way to)處理命名空間資格的標(biāo)識符(the namespace-qualified identifiers)(QNames),使用來作為元素(element)和屬性(attribute)兩個(gè)名字。XName 明顯地(transparently)控制(handle)標(biāo)識符的有效率的原子操作(the efficient atomization of identifiers),允許使用符號(symbols)或純文本(plain strings)任何一個(gè),無論一個(gè) QName 是否需要。

 

XML 元素和屬性分別(respectively)使用 XElement XAttribute 來表示(represented),XElement XAttribute 支持常規(guī)的構(gòu)造語法(normal construction syntax),允許開發(fā)者使用自然的語法(natural syntax)來寫 XML 表達(dá)式:

 

var e = new XElement("Person"
                     
new XAttribute("CanCode"true),
                     
new XElement("Name""Loren David"),
                     
new XElement("Age"31));

var 
= e.ToString();

 

這段代碼符合(corresponds to)下面的 XML

 

<Person CanCode="true">
  
<Name>Loren David</Name> 
  
<Age>31</Age> 
</Person>

 

需要注意的是沒有基于 DOM 的工廠模式(DOM-based factory pattern)被需要來創(chuàng)建 XML 表達(dá)式,ToString 實(shí)現(xiàn)產(chǎn)生出 XML 原文(the textual XML)。XML 元素還能夠通過一個(gè)已存在的 XmlReader 或者一個(gè)字符串文本(string literal)來構(gòu)建(constructed):

 

var e2 = XElement.Load(xmlReader);
var e1 
= XElement.Parse(
@"<Person CanCode='true'>
  <Name>Loren David</Name>
  <Age>31</Age>
</Person>
");

 

XElement 還支持發(fā)出 XML 數(shù)據(jù)(emitting XML),通過使用現(xiàn)有的 XmlWriter 類型。

 

XElement 與查詢操作符(query operators)相吻合(dovetails with),允許開發(fā)者針對非 XML 信息編寫查詢,通過在一個(gè) select 語句體內(nèi)(the body of a select clause)構(gòu)造 XElements 來產(chǎn)生 XML 結(jié)果:

 

var query = from p in people 
            where p.CanCode
            select 
new XElement("Person"
                                  
new XAttribute("Age", p.Age),
                                  p.Name);

 

這個(gè)查詢返回一個(gè) XElements 序列,為了允許 XElements 在這種查詢的結(jié)果之外構(gòu)建,XElement 構(gòu)造器允許元素序列(sequences of elements)可以像參數(shù)(arguments)一樣直接傳遞:

 

var = new XElement("People",
                  from p 
in people 
                  where p.CanCode
                  select 
                    
new XElement("Person"
                                   
new XAttribute("Age", p.Age),
                                   p.Name));

 

這個(gè) XML 表達(dá)式導(dǎo)致下面的 XML

 

<People>
  
<Person Age="11">Allen Frances</Person> 
  
<Person Age="59">Connor Morgan</Person> 
</People>

 

上面的語句有一個(gè)直接地轉(zhuǎn)換成 Visual Basic 的方式,然而,Visual Basic 9.0 也支持 XML 文字(literals)的使用,它允許查詢表達(dá)式通過使用一個(gè)聲明式的 XML 語法(a declarative XML syntax)直接從 Visual Basic 來表達(dá)(expressed)。上面的例子可以用 Visual Basic 來構(gòu)造如下所示:

 

Dim x = _
        
<People>
Select 
<Person Age=(p.Age) >p.Name</Person> _
From In people _
Where p.CanCode
        
</People>

 

這個(gè)例子到目前為止展示了(so far have shown)構(gòu)造了使用一個(gè)語言級集成查詢(a language-integrated query)來構(gòu)造新的 XML 值。而且XElement XAttribute 類型還簡單化了(simplify)信息從 XML 結(jié)構(gòu)中的提取操作(the extraction of information from XML structures)。XElement 提供了訪問者方法(accessor methods)來允許查詢表達(dá)式被應(yīng)用于傳統(tǒng)的 XPath 軸(the traditional XPath axes)。例于,如下的查詢從上面展示的 XElements 中分解出剛才的名字:

 

IEnumerable<string> justNames =
    from e 
in x.Descendants("Person")
    select e.Value;

//justNames = ["Allen Frances", "Connor Morgan"]

 

為了從 XML 中分解出結(jié)構(gòu)型值(structured values),我們簡單地在 select 語句中使用一個(gè)對象初始化表達(dá)式(an object initializer expression):

 

IEnumerable<Person> persons =
    from e 
in x.Descendants("Person")
    select 
new Person 
        Name 
= e.Value,
        Age 
= (int)e.Attribute("Age"
    }
;

 

注意 XAttribute XElement 都支持外部的 cast 操作符(explicit cast operators)來分解出文本的值(text value)為一個(gè)簡單的類型(primitive type),為了處理少見的類型(missing data),我們可以簡單地 cast 成一個(gè)可以為null 的類型(nullable type):

 

IEnumerable<Person> persons =
    from e 
in x.Descendants("Person")
    select 
new Person 
        Name 
= e.Value,
        Age 
= (int?)e.Attribute("Age"?? 21
    }
;

 

在這個(gè)例子中,我們使用一個(gè)缺省數(shù)值 21,當(dāng) Age 屬性不存在時(shí)。

 

Visual Basic 9.0 為元素(Element),屬性(Attribute),和 XElement 的后代訪問者方法(Descendants accessor methods)提供直接的語言支持(direct language support),允許基于 XML 的數(shù)據(jù)(XML-based data)通過使用一個(gè)更加合適直接的語法(more compact, direct syntax)來訪問。我們可以使用這種功能特性(functionality)來編寫前敘的 C# 語句如下所示:

 

Dim persons = _
    Select 
new Person {
      .Name 
= e.Name
      .Age 
= e.@Age ?? 21
      }
 
    From e In xPerson

 

Visual Basic 里,表達(dá)式 e.Name 通過名字 Name 來找出所有的 XElements,表達(dá)式 e.@Age 通過名字 Age 來找出 XAttribute,當(dāng)表達(dá)式 x...Person 通過名字 Person 來獲取 x 的后代集合容器(Descendants collection)中所有的 items

 

8           總結(jié)(Summary

.NET 語言級集成查詢(.NET Language Integrated Query)給 CLR 和語言添加了查詢能力(query capabilities),它們以此為目標(biāo)。查詢技巧(facility)建立在 lambda 表達(dá)式和表達(dá)式樹基礎(chǔ)之上,允許斷言(predicates),映射(projections),和關(guān)鍵詞分解(key extraction)表達(dá)式用來作為不透明的可執(zhí)行的代碼(opaque executable code)或作為透明的內(nèi)存中的數(shù)據(jù)(transparent in-memory data)適合下游的處理和轉(zhuǎn)換(downstream processing or translation)。通過 LINQ 項(xiàng)目定義的標(biāo)準(zhǔn)查詢操作符(standard query operators)工作在任何基于 IEnumerable<T> 接口的信息源(IEnumerable<T>-based information source),并且與 ADO.NETDLinq)和 System.xmlXLinq)相結(jié)合來允許關(guān)系型(relational)的和 XML 數(shù)據(jù)來獲得語言級集成查詢(language integrated query)的好處。

 

 

 

 

全文完, 錯(cuò)誤難免,請批評指正,譯者Naven 2005-10-30

posted on 2005-10-30 23:39 Javen-Studio 閱讀(811) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   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>
            一区二区三区日韩精品| 亚洲一区二三| 欧美777四色影视在线| 极品中文字幕一区| 欧美成人有码| 麻豆久久婷婷| 日韩小视频在线观看专区| 亚洲日本一区二区| 欧美三级乱人伦电影| 亚洲欧美在线高清| 午夜视频一区| 亚洲福利在线看| 最新国产乱人伦偷精品免费网站 | 亚洲大胆人体在线| 欧美精品在线播放| 亚洲一级免费视频| 欧美一区二区国产| 在线观看视频日韩| 亚洲精品一区二区三区樱花 | 亚洲欧美区自拍先锋| 国产偷国产偷亚洲高清97cao| 久久午夜影视| 欧美日本一区二区高清播放视频| 亚洲网站视频| 久久精品视频99| aⅴ色国产欧美| 亚洲欧美日韩精品久久| 精品动漫3d一区二区三区| 亚洲东热激情| 国产欧美日韩免费| 亚洲福利视频二区| 国产精一区二区三区| 欧美a级在线| 国产精品欧美日韩| 亚洲国产精品一区二区www在线| 欧美视频在线观看| 免费一级欧美片在线观看| 欧美性猛交一区二区三区精品| 久久久精品网| 欧美午夜性色大片在线观看| 欧美成人久久| 国产视频久久| av不卡免费看| 亚洲欧洲精品一区二区| 欧美影院视频| 亚洲欧美中文字幕| 欧美日韩第一区日日骚| 免费久久99精品国产| 国产精品永久免费观看| 亚洲毛片一区二区| 亚洲日本理论电影| 久久久久一区二区三区| 欧美一区二区精品在线| 欧美日韩亚洲精品内裤| 亚洲国产一区在线| 亚洲第一黄色| 久久国产视频网| 久久精品久久综合| 国产伦精品一区| 亚洲天堂视频在线观看| 亚洲少妇最新在线视频| 欧美福利专区| 91久久亚洲| 99riav国产精品| 欧美国产在线观看| 亚洲国产精品久久久久久女王| 在线观看av一区| 久久精品日产第一区二区三区 | 亚洲欧洲日韩女同| 美女久久一区| 亚洲国产成人午夜在线一区| 亚洲激情在线视频| 欧美91大片| 亚洲精选视频免费看| 一本一本久久a久久精品牛牛影视| 欧美电影免费观看高清| 亚洲高清视频在线| 日韩视频在线一区| 欧美色道久久88综合亚洲精品| 亚洲免费高清| 性欧美大战久久久久久久免费观看| 欧美日韩综合久久| 午夜免费日韩视频| 蜜臀av性久久久久蜜臀aⅴ| 一区二区亚洲| 欧美韩日一区二区三区| 亚洲人成网站在线观看播放| 一区二区激情| 国产精品自在线| 久久国产婷婷国产香蕉| 欧美成人高清视频| 亚洲视频在线观看三级| 国产麻豆日韩| 久久综合网色—综合色88| 亚洲第一精品影视| 在线一区二区日韩| 国产日本欧美视频| 免费日韩精品中文字幕视频在线| 亚洲片国产一区一级在线观看| 亚洲图片在区色| 激情一区二区| 欧美日韩国产黄| 性做久久久久久免费观看欧美| 欧美成人一区二区三区在线观看| 日韩亚洲国产欧美| 国产一区二区毛片| 欧美日本在线| 久久成人久久爱| 亚洲乱码视频| 快射av在线播放一区| 一二三区精品福利视频| 国内久久精品视频| 欧美日韩一区二区精品| 久久久五月婷婷| 国产精品99久久久久久久久| 免费不卡在线视频| 欧美一区二区三区的| 亚洲日本黄色| 好吊色欧美一区二区三区视频| 欧美日韩日日骚| 久久免费视频一区| 亚洲午夜视频在线| 亚洲精品国产精品国自产在线 | 欧美亚洲在线| 99精品福利视频| 在线观看一区二区精品视频| 欧美日韩网站| 欧美成人精品一区| 久久久美女艺术照精彩视频福利播放 | 99国产精品私拍| 国内精品国产成人| 国产精品一区二区男女羞羞无遮挡| 你懂的国产精品永久在线| 久久精品30| 午夜免费日韩视频| 亚洲欧美久久| 中国女人久久久| 99精品国产在热久久下载| 亚洲高清激情| 亚洲电影第1页| 嫩草国产精品入口| 女同性一区二区三区人了人一| 欧美一区亚洲一区| 久久9热精品视频| 亚洲欧美日韩一区二区在线 | 亚洲电影成人| 激情综合色丁香一区二区| 国产偷国产偷精品高清尤物| 国产精品一区免费视频| 国产精品ⅴa在线观看h| 欧美系列亚洲系列| 欧美性猛交xxxx乱大交蜜桃| 欧美日韩一区在线观看视频| 欧美日韩天堂| 国产精品区一区二区三区| 国产精品乱码一区二区三区| 国产精品日本| 国产一区二区三区直播精品电影| 国产欧美日韩视频一区二区| 国产性色一区二区| 伊人久久婷婷| 亚洲人成免费| 亚洲色诱最新| 久久国产综合精品| 蜜臀久久久99精品久久久久久| 欧美成人午夜视频| 亚洲欧洲日韩女同| 亚洲亚洲精品在线观看| 久久爱www久久做| 久久综合久久久| 欧美精品一区二区三区蜜桃| 欧美日韩一区在线观看视频| 国产精品网站在线| 亚洲第一中文字幕| 亚洲私拍自拍| 久久精品亚洲一区二区三区浴池| 美女诱惑一区| 99日韩精品| 久久精品国产亚洲一区二区| 欧美好吊妞视频| 国产女主播一区| 91久久久在线| 午夜视频一区| 亚洲国产高清一区二区三区| 一本色道久久综合狠狠躁的推荐| 先锋a资源在线看亚洲| 欧美成人乱码一区二区三区| 国产精品日韩欧美| 亚洲欧洲日本在线| 欧美亚洲系列| 欧美高清免费| 久久aⅴ国产紧身牛仔裤| 欧美成人免费全部| 国产麻豆一精品一av一免费| 亚洲精品一线二线三线无人区| 久久本道综合色狠狠五月| 最近看过的日韩成人| 久久精品一区二区| 国产精品一区二区欧美| 一区二区三欧美|