您好,您是想問sqlserver是云存儲還是本地存儲的區(qū)別是什么嗎?sqlserver是云存儲還是本地存儲的區(qū)別是儲存地點(diǎn)不同。云存儲是把sqlserver的數(shù)據(jù)儲存在網(wǎng)絡(luò)上,登陸賬號即可查看調(diào)用,比較方便,而本地存儲是把sqlserver的數(shù)據(jù)儲存在電腦磁盤上,只有在存儲的電腦上才可以查看。
10年積累的做網(wǎng)站、成都網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先做網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有義安免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
Sql Server 區(qū)管理(GAM,SGAM)
大家都知道Sql Server 中數(shù)據(jù)文件存儲的最小單位是頁面(Page),但實(shí)際SQLSERVE并不是以頁面為單位給數(shù)據(jù)分配空間的,Sql Server默認(rèn)的存儲分配單位是盤區(qū)(Extend)。這樣做的主要原因是為了避免頻繁的讀寫IO,提升性能。在表或其它對象分配存儲空間,不是直接分配一個8K的頁面,而是以一個盤區(qū)(Extend)為存儲分配單位,一個盤區(qū)為8個頁面(Size = 8*8K=64K)。
這樣,對區(qū)得操作就會非常頻繁,也要求Sql Server有自己的一套系統(tǒng)管理著數(shù)量眾多的區(qū)。其中最突出的出一個問題,那就是在存儲那些只有少量數(shù)據(jù),不足8K的對象,如果也是分配給一個盤區(qū),就會存在存儲空間上的浪費(fèi),降低了空間分配效率。
為解決上述問題,SQLSERVER提供了一種解決方案,定義了兩種盤區(qū)類型,統(tǒng)一盤區(qū)和混合盤區(qū)。
全局分配映射表 (GAM)?:統(tǒng)一盤區(qū),GAM 頁記錄已分配的區(qū)。每個 GAM 包含 64,000 個區(qū),相當(dāng)于近 4 GB 的數(shù)據(jù)。GAM 用一個位來表示所涵蓋區(qū)間內(nèi)的每個區(qū)的狀態(tài)。如果位為 1,則區(qū)可用;如果位為 0,則區(qū)已分配。?
共享全局分配映射表 (SGAM)?:由多個對象共同擁有該盤區(qū),SGAM 頁記錄當(dāng)前用作混合區(qū)且至少有一個未使用的頁的區(qū)。每個 SGAM 包含 64,000 個區(qū),相當(dāng)于近 4 GB 的數(shù)據(jù)。SGAM 用一個位來表示所涵蓋區(qū)間內(nèi)的每個區(qū)的狀態(tài)。如果位為 1,則區(qū)正用作混合區(qū)且有可用頁。如果位為 0,則區(qū)未用作混合區(qū),或者雖然用作混合區(qū)但其所有頁均在使用中。?
在實(shí)際為對象分配存儲盤區(qū)時,為了提高空間利用率,默認(rèn)的情況下,如果一個對象一開始大小小于8個頁面,就盡量放在混合盤區(qū)中,如果該對象大小增加到8個頁面后,SQLSERVER會為這個對象重新分配一個統(tǒng)一盤區(qū)。
據(jù)區(qū)當(dāng)前的使用情況,GAM 和 SGAM 中每個區(qū)具有以下位模式:
這將簡化區(qū)管理算法。若要分配統(tǒng)一區(qū),數(shù)據(jù)庫引擎將在 GAM 中搜索為 1 的位,并將其設(shè)置為 0。若要查找具有可用頁的混合區(qū),數(shù)據(jù)庫引擎將在 SGAM 中搜索為 1 的位。若要分配混合區(qū),數(shù)據(jù)庫引擎將在 GAM 中搜索為 1 的位,將其設(shè)置為 0,然后將 SGAM 中對應(yīng)的位設(shè)置為 1。若要釋放區(qū),數(shù)據(jù)庫引擎確保將 GAM 位設(shè)置為 1,將 SGAM 位設(shè)置為 0。實(shí)際上,數(shù)據(jù)庫引擎內(nèi)部使用的算法比本主題中介紹的更為復(fù)雜,因?yàn)閿?shù)據(jù)庫引擎在數(shù)據(jù)庫中均勻分布數(shù)據(jù)。但是,由于無需管理區(qū)分配信息鏈,因此即使是實(shí)際算法也會被簡化。
管理Sql Server可用空間
首先摘錄段 MSDN 的一段官方解釋:
頁可用空間 (PFS) 頁記錄每頁的分配狀態(tài),是否已分配單個頁以及每頁的可用空間量。PFS 對每頁都有一個字節(jié),記錄該頁是否已分配。如果已分配,則記錄該頁是為空、已滿 1% 到 50%、已滿 51% 到 80%、已滿 81% 到 95% 還是已滿 96% 到 100%。
將區(qū)分配給對象后,數(shù)據(jù)庫引擎將使用 PFS 頁來記錄區(qū)中的哪些頁已分配或哪些頁可用。數(shù)據(jù)庫引擎必須分配新頁時,將使用此信息。保留的頁中的可用空間量僅用于堆和 Text/Image 頁。數(shù)據(jù)庫引擎必須找到一個具有可用空間的頁來保存新插入的行時,使用此信息。索引不要求跟蹤頁的可用空間,因?yàn)椴迦胄滦械狞c(diǎn)是由索引鍵值設(shè)置的。
在數(shù)據(jù)文件中,PFS 頁是文件頭頁之后的第一頁(頁碼為 1)。接著是 GAM 頁(頁碼為 2),然后是 SGAM 頁(頁碼為 3)。第一個 PFS 頁之后是一個大小大約為 8,000 頁的 PFS 頁。在第 2 頁的第一個 GAM 頁之后還有另一個 GAM 頁(包含 64,000 個區(qū)),在第 3 頁的第一個 SGAM 頁之后也有另一個 SGAM 頁(包含 64,000 個區(qū))。下圖顯示了數(shù)據(jù)庫引擎用來分配和管理區(qū)的頁順序。
看過之后,讓人一頭霧水,真是不知所云,真佩服這些 MSDN 是如何翻譯的,看來中文 MSDN 太不靠譜,最后沒辦法,只能google了
其實(shí)上面說的意思就是:Sql Server 管理可用空間的方法是,查找每個每個頁面是否使用,以及使用情況情況。這時就需要一個頁面來記錄各個頁面的使用情況了,這就是 PFS 頁。
PFS(Page Free Space),也叫頁面自由空間,該頁面用來跟蹤一個文件中每一個特定的頁面的利用率情況。一個文件中第二個頁面(頁碼1)就是PFS頁面,該頁面的每個字節(jié)都記錄了相應(yīng)頁面的分配情況、頁面類型、是否IAM頁、是否包含刪除記錄、以及空間利用率信息;PFS能夠管理和跟蹤8088個頁面的使用情況,即接近64M的空間,以后每8088個頁面將再出現(xiàn)一次。
讓我們首先了解一下PFS的頁面管理字節(jié)的構(gòu)造,管理單位為字節(jié),每字節(jié)管理一個頁面。
第0個bit為保留字節(jié),始終為0
第1個bit表示該頁面是否已分配,我們知道GAM頁用來管理區(qū)是否已分配,但一個區(qū)包含8個頁面,所以用該bit用來準(zhǔn)確定位該區(qū)的某個頁面是否已分配出去了。
第2個bit表示該頁面是否混合分區(qū)的一個頁面。
第3個bit表示該頁面是否是一個IAM(索引分配映射)頁面。
第4個bit表示該頁面中是否包含幻影或已刪除記錄,這有助于SQL Server定期清理幻影或已刪除記錄。
第5~7個頁面表示該頁面的空間使用率情況。
SQL 創(chuàng)建存儲過程:
一、基礎(chǔ)語法:
create?proc?|?procedure?pro_name
[{@參數(shù)數(shù)據(jù)類型}?[=默認(rèn)值]?[output],
{@參數(shù)數(shù)據(jù)類型}?[=默認(rèn)值]?[output],
....
]
as
SQL_statements
二、常見創(chuàng)建存儲過程實(shí)例
1、創(chuàng)建不帶參數(shù)存儲過程
create?proc?proc_get_student
as
select?*?from?student;
執(zhí)行存儲過程:
exec proc_get_student;
2、 帶參存儲過程
create?proc?proc_find_stu(@startId?int,?@endId?int)
as
select?*?from?student?where?id?between?@startId?and?@endId
執(zhí)行存儲過程:
exec?proc_find_stu?2,?4;
3、 帶通配符參數(shù)存儲過程
create?proc?proc_findStudentByName(@name?varchar(20)?=?'%j%',?@nextName?varchar(20)?=?'%')
as
select?*?from?student?where?name?like?@name?and?name?like?@nextName;
執(zhí)行存儲過程:
exec?proc_findStudentByName;
exec?proc_findStudentByName?'%o%',?'t%';
4、 帶輸出參數(shù)存儲過程
create?proc?proc_getStudentRecord(
@id?int,?--默認(rèn)輸入?yún)?shù)
@name?varchar(20)?out,?--輸出參數(shù)
@age?varchar(20)?output--輸入輸出參數(shù)
)
as
select?@name?=?name,?@age?=?age??from?student?where?id?=?@id?and?sex?=?@age;
執(zhí)行存儲過程:
declare?@id?int,
@name?varchar(20),
@temp?varchar(20);
set?@id?=?7;?
set?@temp?=?1;
exec?proc_getStudentRecord?@id,?@name?out,?@temp?output;
select?@name,?@temp;
print?@name?+?'#'?+?@temp;