国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

ASP.NET數(shù)據(jù)庫編程快速入門之技術(shù)慨述

2024-07-10 13:10:30
字體:
供稿:網(wǎng)友

  大約有將近一百萬名開發(fā)人員使用了.net framework的第一個(gè)版本來開發(fā)網(wǎng)站。所以在2003年的夏天,當(dāng)從microsoft傳出將有新版本發(fā)布的傳聞時(shí),許多人的耳朵都豎了起來,這個(gè)新的版本將使得創(chuàng)建asp.net頁面所需的代碼行數(shù)減少70%。像這樣大規(guī)模的提高生產(chǎn)效率在程序設(shè)計(jì)中是不多見的。當(dāng)asp.net 2.0的代碼樣例在2003年秋的microsoft專業(yè)開發(fā)人員大會(huì)(microsoft professional developer’s conference)上演示時(shí),結(jié)果比預(yù)計(jì)的還要好。以前使用asp.net的第一個(gè)版本程序員需要花費(fèi)幾個(gè)小時(shí)才能做出的頁面,現(xiàn)在使用asp.net 2.0只需要幾分鐘就完成了。簡(jiǎn)單來說,在.net framework 2.0最終版本發(fā)布之后,任何繼續(xù)使用第一個(gè)版本創(chuàng)建asp.net頁面的程序人員都將花費(fèi)大量的額外時(shí)間才能達(dá)到相同的結(jié)果。

  也許就像其他任何領(lǐng)域一樣,asp.net 2.0所提供的優(yōu)勢(shì)是能夠方便地將數(shù)據(jù)集成進(jìn)頁面。程序員不再需要知道詳細(xì)的連接、命令以及數(shù)據(jù)閱讀器和數(shù)據(jù)適配器對(duì)象,就能執(zhí)行普通數(shù)據(jù)任務(wù)了。對(duì)于初學(xué)者掌握能力,asp.net 2.0使得基本數(shù)據(jù)的使用簡(jiǎn)單易學(xué),并且有能力進(jìn)行更復(fù)雜的數(shù)據(jù)應(yīng)用。

  .net framework

  microsoft開發(fā)出了作為基本原理的.net和一系列技術(shù),用于在互聯(lián)網(wǎng)中讓計(jì)算機(jī)共同工作。總的目標(biāo)就是讓信息和進(jìn)程在大范圍的系統(tǒng)和設(shè)備之間順暢地交流。.net不是一種語言,也不是一個(gè)特別的產(chǎn)品。更確切地說,它是一套標(biāo)準(zhǔn)和規(guī)范,并已經(jīng)應(yīng)用于自2002年以來microsoft發(fā)布的所有產(chǎn)品中。

  .net包含了一種使用開放標(biāo)準(zhǔn)的xml格式交換信息的標(biāo)準(zhǔn)化格式。可擴(kuò)展標(biāo)記語言(extensible markup language,xml)不需要請(qǐng)求者具備任何有關(guān)數(shù)據(jù)存儲(chǔ)如何保存信息的專門知識(shí)—— 數(shù)據(jù)都以自描述的xml格式取出。同樣地,目前幾乎所有的數(shù)據(jù)存儲(chǔ)都可以用xml來提供信息,這對(duì)于所有.net數(shù)據(jù)客戶都具有吸引力。

  .net支持軟件的web services標(biāo)準(zhǔn),可請(qǐng)求在使用了開放平臺(tái)標(biāo)準(zhǔn)的簡(jiǎn)單對(duì)象訪問協(xié)議(simple object access protocol,soap)和xml的遠(yuǎn)程軟件上運(yùn)行代碼。.net網(wǎng)站可以從另外一個(gè)網(wǎng)站上找到該網(wǎng)站所提供的服務(wù),并使用這些服務(wù)。這樣可以使得網(wǎng)站從其他的網(wǎng)站上獲得html、計(jì)算后的結(jié)果或者數(shù)據(jù)集。

  作為.net開端的一部分,microsoft發(fā)布了一套運(yùn)行時(shí)編程工具和應(yīng)用編程接口(api),稱為.net framework,讓開發(fā)團(tuán)隊(duì)能夠創(chuàng)建.net應(yīng)用程序和xml web services。.net framework由公共語言運(yùn)行庫(common language runtime,clr)和一套統(tǒng)一的類庫組成。

  clr為運(yùn)行的應(yīng)用程序提供了一個(gè)完全管理的執(zhí)行環(huán)境,其中包括幾個(gè)服務(wù),例如程序集裝載和卸載、進(jìn)程和內(nèi)存的管理、安全實(shí)施以及即時(shí)編譯等。clr名稱的意思就是指能夠用多種語言編寫應(yīng)用程序,并且將源代碼編譯成clr能夠讀懂并運(yùn)行的中間語言,而無需考慮原來所使用的語言。這種“語言獨(dú)立性”就是clr的關(guān)鍵特性(也是asp.net的特性),它允許開發(fā)人員使用自己喜歡的語言工作,比如c#、vb或者cobol,都能夠獲得.net framework的常用特性。

  .net framework還包括了一套類庫,這套類庫提供了每一個(gè)應(yīng)用程序所需的常用功能。可以使用.net framework支持的任何語言來訪問這些類庫。由這些類庫提供的服務(wù)(以及相應(yīng)的命名空間)如下:

  · 基本類型(system)

  · 輸入/輸出(system.io)

  · 數(shù)據(jù)訪問(system.data)

  · 安全(system.security)

  · 數(shù)據(jù)結(jié)構(gòu)(system.collections)

  · 配置(system.configuration)

  · 連網(wǎng)(system.net)

  · 反射(system.reflection)

  · 全球化(system.globalization)

  · 繪畫和制圖(system.drawing)

  · 跟蹤和診斷(system.diagnostics)

  · 窗口(客戶端)應(yīng)用程序模型(system.windows.forms)

  · web應(yīng)用程序模型(system.web)

  注意,.net framework包含了兩個(gè)應(yīng)用程序編程模型,一個(gè)用于客戶端應(yīng)用程序(system.windows.forms),另一個(gè)用于基于web的應(yīng)用程序(system.web)。本書著重講解后一個(gè)模型。.net framework中的system.web命名空間是.net framework的一部分,它提供了asp.net功能。換句話說,asp.net就是構(gòu)建應(yīng)用程序的所有.net framework的一部分。

  asp.net

  asp.net是一種用于創(chuàng)建基于web的應(yīng)用程序的編程模型。從本質(zhì)上來說,運(yùn)行時(shí)和.net framework類庫集可以用于創(chuàng)建動(dòng)態(tài)web頁。它需要在web服務(wù)器的環(huán)境中運(yùn)行,例如microsoft internet information server(microsoft互聯(lián)網(wǎng)信息服務(wù)器,iis),并且根據(jù)服務(wù)瀏覽器請(qǐng)求指示在服務(wù)器上執(zhí)行程序。與直接由web服務(wù)器提供的靜態(tài)html不同的是,asp.net頁面實(shí)際上是在服務(wù)器上執(zhí)行以后再產(chǎn)生結(jié)果的。頁面的最后生成也許是由許多不同的指令和/或數(shù)據(jù)源構(gòu)造的。

  asp.net頁面以.aspx擴(kuò)展名存儲(chǔ)。頁面由程序員將文本、標(biāo)記(例如html)以及asp.net特定服務(wù)器標(biāo)記和腳本組合在一起,然后存儲(chǔ)在web服務(wù)器上。可以將存儲(chǔ)后的asp.net頁面看成是一套描述如何創(chuàng)建一個(gè)html頁面的指令。當(dāng)該頁面被請(qǐng)求瀏覽時(shí),服務(wù)器端程序?qū)?huì)用純標(biāo)記來創(chuàng)建一個(gè)客戶端瀏覽器可以讀懂并能呈現(xiàn)(render)的頁面。因?yàn)槌尸F(xiàn)后的輸出是純標(biāo)記,所以任何瀏覽器都能夠讀懂;所有的動(dòng)態(tài)過程都發(fā)生在web服務(wù)器端。asp.net特定服務(wù)器標(biāo)記非常強(qiáng)大,例如,它可以對(duì)用戶的動(dòng)作作出反應(yīng),連接至數(shù)據(jù)存儲(chǔ)以及自動(dòng)創(chuàng)建非常復(fù)雜的html結(jié)構(gòu)。

  正像前面提到的那樣,asp.net只是.net framework的一部分,所以 asp.net頁面可以利用這個(gè)框架提供的所有服務(wù),包括連網(wǎng)、數(shù)據(jù)訪問、安全以及更多其他服務(wù)。因?yàn)閍sp.net可以使用所有這些服務(wù),所以相比以前,能夠創(chuàng)建更加豐富的web應(yīng)用程序。只需花少量的時(shí)間來構(gòu)建所有應(yīng)用程序所需的構(gòu)建塊,而將大多數(shù)時(shí)間用在應(yīng)用程序獨(dú)有的特殊邏輯上。

  asp.net還在web編程中引入了一些獨(dú)特的新技術(shù),可以在典型的動(dòng)態(tài)服務(wù)器頁面(active server pages,asp)上極大地改善開發(fā)模式:

  · 語言獨(dú)立性——因?yàn)閍sp.net是.net framework的一部分,所以可以使用您自己選擇的語言來構(gòu)建asp.net應(yīng)用程序,例如c#、vb或j#。而典型的asp則僅限于jscript或者vbscript頁面。

  · 編譯而不是解釋——與典型的asp在每一次頁面請(qǐng)求時(shí)都解釋編程結(jié)構(gòu)不同,asp.net在服務(wù)器端動(dòng)態(tài)地將頁面編譯成可以運(yùn)行得非常快的本機(jī)編程指令。可以很明顯地看到典型的asp頁面的性能與相同asp.net頁面的性能之間相差的數(shù)量級(jí)別。

  · 事件驅(qū)動(dòng)編程模式——在典型的asp中,頁面總是以自頂向下的線性方式執(zhí)行,并且html標(biāo)記常常與程序指令混合在一起。任何一個(gè)有一定asp經(jīng)驗(yàn)的人都知道這樣會(huì)使得頁面難以閱讀,甚至更加難以維護(hù)。asp.net引入了事件驅(qū)動(dòng)模型,這個(gè)模型允許您將代碼與標(biāo)記內(nèi)容分離,將代碼并入處理專門任務(wù)的有意義的單元中,例如響應(yīng)客戶端的按鈕單擊動(dòng)作。這個(gè)類似vb的事件模型極大地提高了頁面的可讀性和可維護(hù)性。

  · 服務(wù)器控件——典型的asp需要?jiǎng)討B(tài)地將html片斷代碼接合在一起呈現(xiàn),這樣做的結(jié)果就是在應(yīng)用程序中一遍又一遍地編寫相同的代碼(您需要多少次才能從數(shù)據(jù)庫查詢中構(gòu)建一張表格)。asp.net帶給web編程的一個(gè)最大的好處就是能夠?qū)⒐驳某尸F(xiàn)和行為封裝成服務(wù)器控件(server control),可以在應(yīng)用程序中很方便地重復(fù)使用。就像html標(biāo)記一樣,服務(wù)器控件以聲明的形式創(chuàng)建,但是表現(xiàn)為一個(gè)位于服務(wù)器端的可編程對(duì)象,它可以與代碼進(jìn)行交互并輸出定制的動(dòng)態(tài)html呈現(xiàn)。asp.net包含了大約80多個(gè)服務(wù)器控件,這些控件封裝了從標(biāo)準(zhǔn)表單元素到復(fù)雜控件(如網(wǎng)格和菜單)的所有內(nèi)容。

  · 控件設(shè)計(jì)時(shí)間的改善(當(dāng)使用visual web developer時(shí))—— 開發(fā)人員通過使用設(shè)計(jì)時(shí)間界面可以減少花費(fèi)在開發(fā)復(fù)雜頁面上的時(shí)間,這些界面包括敏捷任務(wù)面板、標(biāo)簽級(jí)導(dǎo)航欄和可以設(shè)置控件屬性的向?qū)А?asp.net 2.0

  asp.net的第一個(gè)版本(1.0和1.1)在2001年至2003年間迅速風(fēng)靡了microsoft的開發(fā)陣營(yíng)。程序人員很快便感覺到他們通過使用強(qiáng)大和靈活的.net framework可以大大減少編碼時(shí)間,而且cio們也看到當(dāng)程序員花在解決客戶代碼的疑難問題上的時(shí)間減少時(shí),他們就可以將更多的資源投入到更高級(jí)的it結(jié)構(gòu)的改善上。asp.net確實(shí)是一個(gè)里程碑式的版本,它簡(jiǎn)化了開發(fā)人員的工作。

  但是,就在第一個(gè)版本發(fā)布之前,microsoft的asp.net小組就已經(jīng)在為開發(fā)asp.net 2.0而工作了。他們以下面雄心勃勃的目標(biāo)來開始他們的工作:

  · 使創(chuàng)建一個(gè)典型的web應(yīng)用程序所需代碼行數(shù)減少70%。

  · 提供一套可擴(kuò)展的應(yīng)用程序服務(wù),用來為通用應(yīng)用程序任務(wù)提供構(gòu)建塊,例如成員、角色、個(gè)人化以及導(dǎo)航等。

  · 創(chuàng)建一系列基于任務(wù)的服務(wù)器控件,這些控件可以調(diào)節(jié)上述服務(wù),交付完全、可定制的用戶接口(ui),以最小的代碼量來展示這些服務(wù)。

  · 當(dāng)與.net framework協(xié)同工作提供頁面服務(wù)時(shí),改善iis的性能。

  · 提供管理功能,以便加強(qiáng)asp.net服務(wù)器的部署、管理和運(yùn)行。

  · 改善宿主公司所用的工具,以便可以支持多站點(diǎn)并能夠?qū)㈤_發(fā)人員的項(xiàng)目遷移至公共部署環(huán)境。

  · 讓asp.net的幾乎所有特性都能夠方便地?cái)U(kuò)展或者用定制的高級(jí)任務(wù)的執(zhí)行替換。 在這里,我們有必要再來細(xì)細(xì)地回想一下第一個(gè)目標(biāo),也就是使編寫一個(gè)動(dòng)態(tài)web應(yīng)用程序所需的代碼量減少70%。這有可能嗎?microsoft的asp.net小組已經(jīng)仔細(xì)考慮過各種以定制代碼執(zhí)行的通用任務(wù),并且專門制定了將這些任務(wù)封裝進(jìn)構(gòu)建塊(特別是服務(wù)器控件)的方式,這樣就能夠自動(dòng)地完成這些任務(wù)了。例如,大多數(shù)web應(yīng)用程序都需要安全或者導(dǎo)航或者個(gè)性化服務(wù)來為用戶提供定制的體驗(yàn)。在asp.net 2.0中,這些任務(wù)是通過一系列可配置的應(yīng)用程序服務(wù),以及與這些應(yīng)用程序服務(wù)進(jìn)行對(duì)話的服務(wù)器控件來實(shí)現(xiàn)的,這樣可以極大地減少實(shí)施這些通用服務(wù)所需的應(yīng)用程序的代碼量。但是,在所有這些通用任務(wù)當(dāng)中,有一個(gè)任務(wù)是絕對(duì)獨(dú)立于其他應(yīng)用程序的,這就是數(shù)據(jù)訪問服務(wù)。數(shù)據(jù)是驅(qū)動(dòng)所有動(dòng)態(tài)web應(yīng)用程序的公用線程,所以毫不奇怪,asp.net小組為了減少代碼量和在asp.net 2.0的應(yīng)用程序中執(zhí)行數(shù)據(jù)訪問所需的概念,而制訂了一些大膽的目標(biāo):

  · 在asp.net中可以通過聲明的(無代碼)方式來定義一個(gè)數(shù)據(jù)源。

  · 可以通過聲明的(無代碼)方式用ui控件顯示數(shù)據(jù),無需在頁面的執(zhí)行生存期中的特定時(shí)間進(jìn)行顯式的數(shù)據(jù)綁定。

  · 可以通過聲明的(無代碼)方式執(zhí)行通用數(shù)據(jù)任務(wù),例如排序、分頁、過濾、更新、插入以及刪除數(shù)據(jù)。

  · 可以使用多種ui控件來顯示數(shù)據(jù),包括靈活的網(wǎng)格/詳細(xì)控件,該控件既可以顯示又可以操作數(shù)據(jù)。

  · 為創(chuàng)建定制的數(shù)據(jù)源,啟用可擴(kuò)展的模型來支持新的數(shù)據(jù)類型。

  asp.net 2.0具有一些程序員可以使用的特定的服務(wù)器控件,用于在頁面上添加數(shù)據(jù)交互。這些專門的數(shù)據(jù)控件分為兩組:數(shù)據(jù)源控件和數(shù)據(jù)綁定控件。數(shù)據(jù)源控件創(chuàng)建與數(shù)據(jù)庫的鏈接。數(shù)據(jù)綁定控件則從數(shù)據(jù)源控件獲取信息,并在頁面上創(chuàng)建呈現(xiàn)。這種簡(jiǎn)單的雙控件模式可用于多種情況。對(duì)于多種數(shù)據(jù)庫類型,甚至是非關(guān)系型數(shù)據(jù)源,都有相應(yīng)的數(shù)據(jù)源控件。同樣地,有多種數(shù)據(jù)綁定控件可用來在頁面上生成表格、樹型、列表以及其他數(shù)據(jù)格式。在前面我們已對(duì)asp.net進(jìn)行了介紹,同時(shí)講述了asp.net的一些理論,現(xiàn)在開始介紹本書剩余部分的細(xì)節(jié)內(nèi)容:數(shù)據(jù)源控件和數(shù)據(jù)綁定控件的使用。數(shù)據(jù)源控件以及附帶產(chǎn)品包括如下條目:

  · sqldatasource控件,用于與microsoft sql server和其他數(shù)據(jù)庫進(jìn)行連接

  · accessdatasource控件,用于與mdb文件連接

  · objectdatasource控件,用于與中間層對(duì)象連接

  · xmldatasource控件,用于xml文件或者數(shù)據(jù)流

  · sitemapdatasource控件,用于以asp.net 2.0站點(diǎn)地圖格式存儲(chǔ)的xml文件額外的控件已經(jīng)由第三方開發(fā)。

  在數(shù)據(jù)綁定控件中,有很多與asp.net 1.x中的相似,有一些則是asp.net 2.0全新開發(fā)的:

  · listbox、dropdownlist和bulletedlist、checkboxlist、radiobuttonlist

  · adrotator是實(shí)現(xiàn)舊功能的數(shù)據(jù)綁定控件

  · datalist和repeater以靈活的布局方式提供數(shù)據(jù)

  · datagrid(與asp.net 1.x中的相同)和gridview(第2個(gè)版本中的新控件)用于表格數(shù)據(jù)

  · detailsview和formview以輕松的導(dǎo)航提供記錄的信息

  · treeview用于顯示分級(jí)數(shù)據(jù)

  總之,數(shù)據(jù)源控件和數(shù)據(jù)綁定控件將會(huì)是本書重點(diǎn)介紹的對(duì)象。

  在.net framework 2.0公開beta版本發(fā)布之前,少數(shù)的幾個(gè)程序組就已經(jīng)被允許查看工作代碼,并希望盡快獲得他們的反饋。結(jié)果,所有的反應(yīng)只有一個(gè),那就是熱烈,“太好了!”然后就是“什么時(shí)候我才能用asp.net 2.0替換我的asp.net 1.x應(yīng)用程序?”。現(xiàn)在beta發(fā)布版本已經(jīng)在手邊,我們無需再等待了。

  ado.net

  ado.net是.net framework中的一套類庫,它將會(huì)讓您更加方便地在應(yīng)用程序中使用數(shù)據(jù)。microsoft收集了過去幾十年中最佳的數(shù)據(jù)連接的實(shí)踐操作,并編寫代碼實(shí)現(xiàn)這些實(shí)踐。這些代碼被包裝進(jìn)了一些對(duì)象中,以便其他軟件可以方便地使用。

  ado.net中的代碼處理了大量的數(shù)據(jù)庫特有的復(fù)雜情況,所以當(dāng)asp.net頁面設(shè)計(jì)人員想讀取或者寫入數(shù)據(jù)時(shí),他們只需編寫少量的代碼,并且這些代碼都是標(biāo)準(zhǔn)化的。就像asp.net一樣,ado.net不是一種語言。它是對(duì)象(類)的集合,在對(duì)象(類)中包含了由microsoft編寫的代碼。可以使用諸如visual basic或者c#等編程語言來在對(duì)象外部運(yùn)行這些代碼。

  可以將ado.net看作是一個(gè)介于數(shù)據(jù)源和數(shù)據(jù)使用者之間的非常靈巧的轉(zhuǎn)換層。ado.net可以接受數(shù)據(jù)使用者語言中的命令,然后將這些命令轉(zhuǎn)換成在數(shù)據(jù)源中可以正確執(zhí)行任務(wù)的命令。但是,就像您將會(huì)看到的那樣,asp.net 2.0提供了服務(wù)器端數(shù)據(jù)控件,可以更方便地與ado.net交互工作,所以有的時(shí)候這基本上減少了直接使用ado.net對(duì)象的需求。

  很多讀者已經(jīng)有使用asp.net早期版本的經(jīng)驗(yàn)了。這一小節(jié)將回顧一下這種模式,目的是演示您需要通過ado.net對(duì)象將數(shù)據(jù)引入web頁中的這一過程。對(duì)那些從來都沒有使用過早期版本的讀者來說,可以將本小節(jié)作為一個(gè)新奇的故事,類似于在發(fā)現(xiàn)乙醚之前進(jìn)行的外科技術(shù)研究。在以前,創(chuàng)建一個(gè)簡(jiǎn)單典型的asp.net 1.x版本的頁面需要如下代碼:

<script runat="server">

sub page_load(byval sender as object, byval e as system.eventargs)

bulletedlist1.datasource = getauthorsbystate("ca")

bulletedlist1.databind()

end sub

shared function getauthorsbystate(byval state as string) as system.data.dataset

dim connectionstring as string =

"server=(local); database=pubs; trusted_connection=true"

dim dbconnection as system.data.idbconnection = new system.data.sqlclient.sqlconnection(connectionstring)

dim querystring as string = "select [authors].[au_id], [authors].[au_fname], [authors].[au_lname], [authors].

[state] from [authors] where ([authors].[state] = @state)"

dim dbcommand as system.data.idbcommand = new system.data.sqlclient.sqlcommand

dbcommand.commandtext = querystring

dbcommand.connection = dbconnection

dim dbparam_state as system.data.idataparameter = new system.data.sqlclient.sqlparameter

dbparam_state.parametername = "@state"

dbparam_state.value = state

dbparam_state.dbtype = system.data.dbtype.stringfixedlength

dbcommand.parameters.add(dbparam_state)

dim dataadapter as system.data.idbdataadapter = new system.data.sqlclient.sqldataadapter

dataadapter.selectcommand = dbcommand

dim dataset as system.data.dataset = new system.data.dataset

dataadapter.fill(dataset)

return dataset

end function

</script>

<html><head runat="server"><title>untitled page/title></head>

<body>

<form id="form1" runat="server"><div>

<asp:bulletedlist id="bulletedlist1" datatextfield= "au_lname" runat="server" />

</div></form>

</body></html>

  以上示例對(duì)數(shù)據(jù)庫執(zhí)行了一條簡(jiǎn)單的sql select語句,并將結(jié)果與一個(gè)bulletedlist控件綁定。頁面中有一個(gè)名為getauthorsbystate的方法,該方法創(chuàng)建了用來完成這個(gè)任務(wù)的幾個(gè)ado.net對(duì)象:

  · sqlconnection對(duì)象表示與數(shù)據(jù)庫服務(wù)器進(jìn)行連接

  · sqlcommand對(duì)象表示要執(zhí)行的sql select命令

  · sqlparameter對(duì)象代表了一個(gè)將被命令中的標(biāo)記代替的值

  · sqldataadapter表示填充命令中的dataset對(duì)象的能力

  · dataset表示命令結(jié)果,可以與bulletedlist進(jìn)行綁定

  在page_load事件中,調(diào)用getauthorsbystate方法并生成dateset結(jié)果,然后將這個(gè)結(jié)果賦給bulletedlist的datasource屬性。接著,調(diào)用databind()使得bulletedlist用這個(gè)數(shù)據(jù)結(jié)果將自己同步。我們?cè)陧撁鎴?zhí)行生存期中的適當(dāng)?shù)臅r(shí)候調(diào)用databind(),這樣的做法是asp.net 2.0在一般情況下尋找并消除的一個(gè)關(guān)鍵步驟。實(shí)際上,在大多數(shù)情況下, asp.net 2.0根本不需要與ado.net進(jìn)行交互操作。但是,理解上述ado.net對(duì)象之間的關(guān)系是非常有用的,這樣我們就可以討論 asp.net 2.0是如何改進(jìn)這個(gè)模式的。

  asp.net 2.0和數(shù)據(jù)訪問

  asp.net 2.0給我們提供了一個(gè)改良的數(shù)據(jù)訪問模式,這個(gè)模式減少了在 asp.net 1.x中執(zhí)行數(shù)據(jù)綁定所需的代碼量。首先,無需編程實(shí)現(xiàn)實(shí)例化、設(shè)置屬性以及調(diào)用前述列表中的ado對(duì)象的方法。您需要做的就是在頁面上簡(jiǎn)單地添加服務(wù)器端控件并設(shè)置屬性。當(dāng)呈現(xiàn)頁面時(shí),asp.net 2.0將會(huì)自動(dòng)地執(zhí)行所有的對(duì)象實(shí)例化,并調(diào)用方法創(chuàng)建并顯示數(shù)據(jù)。請(qǐng)將以下asp.net 2.0代碼與上面的代碼進(jìn)行對(duì)比:

<html>

<head runat="server"><title>demo</title></head>

<body>

<form id="form1" runat="server">

<asp:sqldatasource id="sqldatasource1" runat="server" selectcommand="select au_lname from authors where (state = @state)"

connectionstring="server=hpserv; integrated security=true;database=pubs">

<selectparameters>

<asp:parameter type="string" defaultvalue="ca" name="state" />

</selectparameters>

</asp:sqldatasource>

<asp:bulletedlist id="bulletedlist1" runat="server" datasourceid="sqldatasource1"

datatextfield="au_lname">

</asp:bulletedlist>

</form>

</body></html>

  第二個(gè)改進(jìn)來自于對(duì)在頁面生存期中的事件敏感的服務(wù)器端控件。asp.net 2.0 服務(wù)器端控件能夠在正確的時(shí)間做出正確的動(dòng)作。請(qǐng)注意在asp.net 2.0頁面中對(duì)頁面生存期中的事件的任何引用。asp早期版本的學(xué)生一般都會(huì)對(duì)在頁面生存期中執(zhí)行多種任務(wù)感到迷惑,特別是數(shù)據(jù)綁定。因此,很多asp.net 1.x頁面都會(huì)有這樣的讓程序員編寫代碼的遭遇,即在錯(cuò)誤的事件下調(diào)用databind,或者在多個(gè)事件中多次調(diào)用databind。這些定時(shí)操作現(xiàn)在都可以通過asp.net 2.0的服務(wù)器端數(shù)據(jù)控件來自動(dòng)完成。

  請(qǐng)注意在前面的asp.net 2.0的代碼中使用了兩個(gè)服務(wù)器端控件。第一個(gè)是數(shù)據(jù)源控件,本例中是sqldatasource控件。該控件在后臺(tái)建立了所有顯示數(shù)據(jù)所需的ado連接對(duì)象,包括connection、command以及datareader或者dataset對(duì)象。然后,使用了一個(gè)名為bulletedlist的數(shù)據(jù)綁定控件,用來獲取數(shù)據(jù)源控件的數(shù)據(jù),并在頁面上呈現(xiàn)。

  術(shù)語

  在完成介紹性內(nèi)容之前,我將提供一個(gè)到目前為止所用到的術(shù)語表。

  · 動(dòng)態(tài)web頁—— 作為代碼存儲(chǔ)在web服務(wù)器上的文件,當(dāng)被請(qǐng)求時(shí),可轉(zhuǎn)換為html。當(dāng)頁面被轉(zhuǎn)換時(shí),他們可以根據(jù)用戶和網(wǎng)站擁有者的實(shí)時(shí)情況而按照不同的請(qǐng)求來獲取不同的表單。

  · iis—— 在windows中內(nèi)置的web服務(wù)器,用于通過tcp/ip向請(qǐng)求者提供web頁。運(yùn)行于windows 2000或者windows xp professional上的iis可以使用.net framework類來提供asp.net web頁。

  · .net framework—— 一組包含microsoft編寫的代碼的類,可以使得開發(fā)應(yīng)用程序更加方便和快捷,并且更易于在互聯(lián)網(wǎng)上運(yùn)行。很多類都已經(jīng)被封裝進(jìn)能夠啟用.net 的大約十多個(gè)microsoft產(chǎn)品當(dāng)中了。

  · clr(公共語言運(yùn)行庫)—— .net framework的一項(xiàng)特性,可以讓編程人員用多種語言編寫代碼,然后將代碼編譯成可用來部署的單獨(dú)、統(tǒng)一的語言。

  · asp.net—— .net framework中的運(yùn)行時(shí)和類庫集,用來創(chuàng)建動(dòng)態(tài)web應(yīng)用程序。

  · 數(shù)據(jù)存儲(chǔ)—— 數(shù)據(jù)被存放和管理的地方。所有的rdbms都可用于數(shù)據(jù)存儲(chǔ),但是有些數(shù)據(jù)存儲(chǔ)就不是rdbms,因?yàn)樗鼈儾皇顷P(guān)系型的。

  · 數(shù)據(jù)庫或關(guān)系型數(shù)據(jù)庫管理系統(tǒng)(rdms)—— 一種可以讀取和操縱數(shù)據(jù)的軟件。大多數(shù)系統(tǒng)包含了用來設(shè)計(jì)和測(cè)試數(shù)據(jù)庫的工具,以及優(yōu)化過程的工具。一個(gè)rdbms必須按照標(biāo)準(zhǔn)化形式(關(guān)系型格式)存儲(chǔ)數(shù)據(jù)。

  · database模式(或數(shù)據(jù)庫元數(shù)據(jù))—— 數(shù)據(jù)庫結(jié)構(gòu),包括表和關(guān)系的設(shè)計(jì)。該模式不包括實(shí)際的數(shù)據(jù)值。

  · microsofttm access—— 一種基于mdb文件格式、jet引擎以及一系列用于創(chuàng)建和使用數(shù)據(jù)庫的工具的rdms。access價(jià)格便宜,容易學(xué)習(xí),能被廣泛接受并且已經(jīng)被部署到很多機(jī)器上。但是,它不支持太多的并發(fā)用戶。

  · jet—— 運(yùn)行在后臺(tái)并使用mdb(access)文件的數(shù)據(jù)庫引擎。jet可以直接從其他軟件(例如.net或access)接受命令來讀取或者修改mdb文件。

  · 結(jié)構(gòu)化查詢語言(structured query language,sql)—— 一種被數(shù)據(jù)使用者用來從數(shù)據(jù)提供程序那里請(qǐng)求讀取或者寫入數(shù)據(jù)的語言。經(jīng)過近十年的發(fā)展,sql已經(jīng)成為與rdbms通信的標(biāo)準(zhǔn)。

  · microsofttm sql server—— 一種企業(yè)級(jí)的rdbms,可以支持大量的數(shù)據(jù)和大量的并發(fā)用戶。

  · microsofttm sql server express(sse)—— 基于microsoft sql server數(shù)據(jù)庫引擎的可免費(fèi)獲得的數(shù)據(jù)庫引擎。與sql server不同的是,sse能提供的同時(shí)數(shù)據(jù)連接數(shù)量有限,并且只有少數(shù)幾個(gè)功能。本書將在大多數(shù)示例中使用sse。

  · microsofttm data engine(msde)—— 與sse類似,但是基于sql server引擎的早期版本。msde將在本書的練習(xí)中使用。

  · xml—— 一種標(biāo)準(zhǔn)的數(shù)據(jù)格式,每個(gè)值都被存儲(chǔ)并描述。xml不是非常有效率(用于描述的空間通常會(huì)超過數(shù)據(jù)的大小),但是卻能被很多不同的數(shù)據(jù)管理系統(tǒng)方便地讀取。

  · web頁編輯器—— 一種允許打開和修改頁面的軟件。最常用的編輯器是記事本。visual studio、visual web developer和asp.net web matrix與其他工具打包成一個(gè)編輯器,用以提高效率。 · 集成開發(fā)環(huán)境(integrated development environment,ide)—— 一套用來幫助編程人員開發(fā)代碼的工具。visual studio就是一個(gè)非常強(qiáng)大的ide;web asp.net web matrix也提供了很多工具。典型的ide應(yīng)當(dāng)包含一個(gè)web頁編輯器。

  · ado.net—— 由microsoft編寫的類(代碼)的集合,作為數(shù)據(jù)存儲(chǔ)(例如access或者xml文件)和數(shù)據(jù)使用者(例如asp頁面)之間的中間件。

  · 連接—— 一個(gè)ado對(duì)象,表示數(shù)據(jù)使用者和數(shù)據(jù)提供程序之間的惟一路徑。

  · 命令—— 一個(gè)ado對(duì)象,表示一條可以被傳遞給數(shù)據(jù)庫的sql語句。

  · 參數(shù)—— 一個(gè)ado對(duì)象,表示在語句進(jìn)入數(shù)據(jù)庫之前可以被插入common object(sql語句)中的多個(gè)數(shù)據(jù)。

  · dataset—— 一個(gè)ado對(duì)象,表示集成至記錄或字段中的一組數(shù)據(jù)。

  · 服務(wù)器控件—— 一組獨(dú)立的代碼(一個(gè)對(duì)象),用于在服務(wù)器上執(zhí)行任務(wù),生成兼容html的并且發(fā)送至瀏覽器的頁面。通過viewstate,服務(wù)器端控件可以維持其狀態(tài)。

  · 數(shù)據(jù)源控件—— 一種服務(wù)器端控件,可以創(chuàng)建專門的、惟一的數(shù)據(jù)庫連接。它提供了ado對(duì)象的一種抽象并且使得編寫asp.net 2.0頁面更加快速和容易。數(shù)據(jù)源控件可用于microsoft sql server、access、xml以及其他數(shù)據(jù)源。

  · 數(shù)據(jù)綁定控件—— 一種服務(wù)器端控件,可以從數(shù)據(jù)源控件中獲得數(shù)據(jù)并在頁面上呈現(xiàn)它。數(shù)據(jù)綁定控件將程序員從編寫諸如<table>的html標(biāo)記中解脫出來。數(shù)據(jù)綁定控件可用于呈現(xiàn)表格、列表、樹型以及其他結(jié)構(gòu)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 吉安市| 吉隆县| 云林县| 天祝| 遵化市| 奉化市| 东辽县| 湘阴县| 金阳县| 彭阳县| 光泽县| 成都市| 涟水县| 瑞丽市| 错那县| 武山县| 济南市| 东城区| 浦县| 左贡县| 吴堡县| 惠水县| 乌恰县| 牡丹江市| 邵阳市| 横山县| 新乡县| 琼结县| 浦城县| 鄂托克前旗| 绥阳县| 汝州市| 山阴县| 剑阁县| 山西省| 民县| 北碚区| 渝北区| 绍兴县| 茌平县| 襄城县|