這篇文章給大家介紹如何理解SQL Server數(shù)據(jù)體系和應用程序邏輯,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:網(wǎng)站建設、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的克山網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!
很多人都用過SQLServer數(shù)據(jù)庫,但是很少的人真正理解SQLServer數(shù)據(jù)體系和應用程序邏輯,其實,在許多用SQLServer實現(xiàn)的新的企業(yè)系統(tǒng)設計中,系統(tǒng)設計師需要在給數(shù)據(jù)結構和管理應用程序邏輯的定位上做出具有關鍵性意義的決定。下面創(chuàng)新互聯(lián)小編來講解下SQLServer數(shù)據(jù)體系和應用程序邏輯怎樣應用?
SQLServer數(shù)據(jù)體系和應用程序邏輯怎樣應用
使用TSQL,開發(fā)者可以創(chuàng)建保存過程,在保存過程中用一段可重用、預編譯而且擁有自己的許可設置的代碼塊來封裝數(shù)據(jù)訪問。數(shù)據(jù)庫中每個表格都有一組叫做triggers的特殊的保存過程。當?shù)讓訑?shù)據(jù)庫發(fā)生特定的數(shù)據(jù)庫事件(如Insert、Delete或者Update)時,trigger就被“觸發(fā)”了。使用triggers,開發(fā)者就可以編寫基于事件的事務邏輯,這樣,給定表格的Insert、Delete和Update事件就可以驅動其它表格的變化。
既然有了這樣的靈活性,那么我們?yōu)槭裁床槐M可能用TSQL寫更多的事物邏輯呢
使用TSQL來開發(fā)應用程序邏輯存儲
TSQL不僅可以作為單個應用程序的邏輯倉庫,它也可以是一個訪問相同數(shù)據(jù)的應用程序組的邏輯倉庫——這有幾個邏輯上的原因。通過對數(shù)據(jù)的集中處理和管理SQLserver中數(shù)據(jù)的規(guī)則,你可以配置這樣的安全體系——即應用程序在通過事務規(guī)則之前,不可以訪問底層數(shù)據(jù)庫。
這是大多數(shù)兩層客戶——服務器應用程序的常見數(shù)據(jù)庫范例。該體系把所有的事務邏輯和數(shù)據(jù)訪問交給后端的服務器而把豐富的表示邏輯交給客戶端??蛻艄芾硎聞者^程和數(shù)據(jù)的視(view),但不在本地處理除顯示之外的其它事務。假如把所有的事務邏輯放到中央倉庫去,那么這個體系還有降低管理成本的潛力,但這會付出降低了可測性的代價。
我最近接觸了一個客戶,它花了數(shù)百個人月(一個人工作一個月的工作量)和數(shù)以千計的美元來設計一個非常復雜的、用TSQL管理所有應用程序邏輯的應用程序。盡管該體系非常精巧、在10到15個用戶的情況下也運行良好,但是假如有20個用戶,速度就非常慢。通過給SQLserver增加處理器的方法,該系統(tǒng)可以允許60個用戶同時使用。但是這距離100個用戶的設計目標還有很大一段距離,這就使得該公司在Internet上開放該應用程序的計劃無法實施下去。由于存儲過程和trigger只能操作本地數(shù)據(jù),該公司無法把該應用程序分解成多個SQLserver以提高可測性。結果,該公司不得不大規(guī)模的修改它。
SQLServer數(shù)據(jù)體系和應用程序邏輯怎樣應用
在應用程序邏輯中使用.NET類
上面那家公司在經(jīng)過一段曲折后所發(fā)現(xiàn)的問題,大多數(shù)體系設計師在體系設計階段都會重新認識到——應用程序邏輯包含在一組.NET類的n層體系可以增加該應用程序的靈活性和可測性。由于TSQL是一種以管理數(shù)據(jù)為主要目的的語言,因此它不夠靈活,但是我們仍可以用TSQL編寫出復雜的事務邏輯。
假如開發(fā)者使用.NET框架,那么他們可以在開發(fā)核心事務過程時做出自己的語言選擇。這個靈活性可以讓你對應用程序要求和開發(fā)語言或者資源進行最合理的搭配。而且假如適當開發(fā),封住這些事務過程的對象可以在多臺機器上運行并共享同樣的底層數(shù)據(jù)庫server。在與處理TSQL事務邏輯無關的情況下,SQLserver可以應付大量的并發(fā)請求。
行操作(rowoperation)和集操作(setoperations)
在規(guī)劃體系階段時判斷使用行操作還是集操作的一個指導思想就是:假如使用TSQL就使用集操作,假如使用.NET則進行行操作。通過網(wǎng)絡連接來提供大量的數(shù)據(jù)會影響應用程序的整體性能,所以只要有可能就使用server來處理它們——這樣做是很有意義的。但是從內存和處理能力的角度來看,SQLServer的指針(cursor)是非常昂貴的對象,因此創(chuàng)建一個指針來遍歷集合中的所有記錄并依次處理這些記錄一般來說并沒有多大意義。
當你需要執(zhí)行基于行的處理,而這些處理包括了復雜的程序邏輯或者占用CPU比較厲害的操作時,你就應該從server中查詢這些行并在中間層來處理它們。
假如你想通過一個例子來看看如何把數(shù)據(jù)訪問邏輯封裝到一個中間層對象中去,請從MSDN中下載數(shù)據(jù)訪問應用程序模塊。這是一個提供代碼的、可重用的數(shù)據(jù)訪問子系統(tǒng),你可以根據(jù)它來編寫自己的數(shù)據(jù)庫或者特性應用程序的數(shù)據(jù)訪問對象。
通過創(chuàng)建可重用的.NET應用程序框架來處理大多數(shù)應用程序邏輯、并用基于TSQL的保存過程來作為服務器端的集操作的安全限制和機制,那么你就可以創(chuàng)建同時擁有TSQL和.NET這兩者優(yōu)點的應用程序了。
關于如何理解SQL Server數(shù)據(jù)體系和應用程序邏輯就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
本文名稱:如何理解SQLServer數(shù)據(jù)體系和應用程序邏輯
網(wǎng)站URL:http://aaarwkj.com/article46/pcdpeg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設、網(wǎng)站制作、全網(wǎng)營銷推廣、網(wǎng)站排名、網(wǎng)站改版、Google
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)