色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

利用同義詞簡化SQL Server 2005開發

瀏覽:4日期:2023-10-30 18:58:16
一. 引言如果你曾經使用SQL Server開發過任何軟件,那么你肯定會習慣于使用四部分標識符來參考一個對象:[[[server.][database].][schema_name].]object_name正如上面的方括號所顯示的,該語法的不同部分可以被忽略,只要你提供足夠的表達來無二義地標識你的對象即可。例如,下面所有這些表達都可能參考相同的對象:Server1.AdventureWorks.Production.ProductCategoryAdventureWorks.Production.ProductCategoryAdventureWorks..ProductCategoryProductCategory在大多數情況下,你可以僅使用三部分名字而忽略服務器名-除非你是在處理在一個連接的服務器上的對象。默認情況下,所有對象的上下文都是本地數據庫-你的SQL語句在其中執行。但是,有些情況下,或者更為準確地說,你必須使用這整個四部分命名(或稱作一種全稱限定名)。但是,在SQL Server 2005中,這種情況有所改變。二. 熟悉同義詞SQL Server 2005引入了一個同義詞的概念,這是一個單部分的名字,它可以替換在許多SQL語句中的一個兩、三或四部分的名字。使用同義詞可以讓你減少輸入,而且還能提供一個抽象層來為你保護底層對象的改變。為了理解其工作原理,讓我們先看一下創建同義詞的語法。下面是CREATE SYNONYM語句的語法: CREATE SYNONYM [schema_name.]synonym_name FOR object_name在此,object_name是一個SQL Server對象(全稱限定已經足以能夠標識出這個對象)的名字,而synonym_name是你想賦給它的新名字。如果你不想為同義詞指定一種模式,那么SQL Server使用當前的用戶的默認模式。當你創建同義詞時,相應的對象不需要存在,因為同義詞是遲綁定的:當你實際上使用同義詞時,SQL Server僅僅檢查基對象。例如,在AdventureWorks示例數據庫中,你可以以下列方式創建一個同義詞:CREATE SYNONYM ProdCatFOR AdventureWorks.Production.ProductCategory之后,你可以繼續使用在SQL語句中的同義詞了。例如:SELECT * FROM ProdCat圖1顯示出相應的結果:利用同義詞簡化SQL Server 2005開發當你使用完一個同義詞后,你可以使用DROP SYNONYM語句來去掉它,它具有你期望的語法格式:DROP SYNONYM [schema_name.]synonym_name三. 幾點細節當然,對于同義詞的使用上也存在一些限制。對于初學者來說,你不能為任何東西都創建一個同義詞。SQL Server 2005比以前引入了更多的對象,但是同義詞僅限于應用于核心集的最有用的一些對象中:· 表· 視圖· 存儲過程· CLR存儲過程· CLR函數· 復制過濾過程· 擴展存儲過程· SQL標量,表值以及內聯表值函數關于在什么情況下使用同義詞還存在一些限制。一般來說,你可以在下面這些T-SQL語句中使用一個同義詞:· SELECT· sub-selects· UPDATE· INSERT· DELETE· EXECUTE如果你仔細考慮一下,那么第二個表不應該太奇怪:它包含了最常用的where語句。注意,你不能在一個DDL語句中參考一個同義詞。如果你想使用ALTER TABLE來改變ProductCategory表中的內容,那么,你需要使用基表而不是使用ProdCat同義詞。為了創建一個同義詞,你需要CREATE SYNONYM權限。在創建一個同義詞后,它就有了與其自己相關聯的GRANT,DENY和REVOKE許可權。四. 把同義詞作為一個抽象層除了節省你的輸入時間外,同義詞還可以用作你的數據庫的不穩定的或經常更新部分的一個抽象層。這是因為同義詞及其基對象之間的綁定僅在運行時刻檢查,而不是在設計時刻。為了說明這個問題,如果你重新定義ProdCat同義詞,請研究下面發生什么情況:DROP SYNONYM ProdCatCREATE SYNONYM ProdCatFOR AdventureWorks.Production.ProductCategorySELECT * FROM ProdCatDROP SYNONYM ProdCatCREATE SYNONYM ProdCatFOR AdventureWorks.Production.CultureSELECT * FROM ProdCat注意,當你任何時候想改變一個同義詞時,你需要使用DROP和CREATE;不存在ALTER SYNONYM語句。圖2顯示出運行這個批處理語句的結果。注意,在此,語句SELECT * FROM ProdCat與前面的第二次執行結果懸殊很大,因為同義詞被重新定義以參考一個不同的表。當然,你可以把這種行為應用于你自己的應用程序中。例如,假定你有一個程序,它需要分析來自于多種數據庫的顧客數據。不是把基表與單個數據庫連接起來或斷開連接,或編寫復雜的選擇表格進行分析的SQL,而是使用同義詞。定義一個同義詞,例如DataTable,來參考你想使用的數據的四部分名字,并且重新定義它-無論何時你想要切換源數據。當然,這種遲綁定也是一把雙刃劍。因為SQL Server并不追蹤是否一個同義詞指向任何東西,它也不會進行任何模式綁定排序。如果你刪除一個應用于另一個語句中的同義詞,那么你可能直到試圖運行該語句時才發現出了問題。五. 小結你能夠開發自己的下一個SQL Server應用程序而不使用同義詞嗎?當然可以。它們并沒有為數據庫表帶來根本性的新內容;你可以總是使用完全限定名字-在任何你想使用一個同義詞的地方。但是有時把這些'小東西'加入到你的產品是一件不錯的事情,就因為它們能夠實現更少的輸入和帶給開發者一種更容易的體驗。也許在一個應用程序的開發過程的某一階段同義詞將僅會節省你10分鐘時間,但是所有這些小的10分鐘相加應該是個不少的數目吧!
標簽: Sql Server 數據庫
主站蜘蛛池模板: 欧美一区二区三区在线观看 | 99re6这里有精品热视频在线 | 黄页网站18以下禁止观看 | 欧美一区二区三区视频 | 高清性色生活片欧美在线 | 日本黄色官网 | 国产成人精品无缓存在线播放 | www.xxx.国产 | 美女双腿打开让男人桶爽网站 | 中文在线观看视频 | 一级毛片成人免费看免费不卡 | 久久久久久久久a免费 | 国产一区二区三区四区五区 | 国产欧美日韩综合精品一区二区 | 日本乱人伦片中文三区 | 国产成人精品午夜视频' | 亚洲日本在线观看 | 成年人免费看 | 欧美日韩高清在线观看一区二区 | 好吊妞998视频免费观看在线 | 自拍偷拍欧美视频 | 亚洲欧美精品国产一区色综合 | 一级女性全黄生活片免费 | 114毛片免费观看网站 | 色偷偷亚洲第一成人综合网址 | 男女精品视频 | 国产www| 午夜视频在线观看一区 | 亚洲精品成人久久久影院 | 成人a视频片在线观看免费 成人a视频在线观看 | 国产精自产拍久久久久久 | 亚洲一级特黄特黄的大片 | 日本a级毛片视频播放 | 久草a视频| 中文字幕亚洲精品久久 | 久久在现| 成人禁在线观看午夜亚洲 | 精品欧美小视频在线观看 | 99久久国语露脸精品对白 | 在线综合亚洲欧美自拍 | 男人都懂的网址在线看片 |