亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

使用SQL Server數據庫快照形成報表

添加時間:2014-4-10 17:42:58  添加: 思海網絡 
在SQL Server 2005中,它的另外一個強大的新特點是數據庫快照。數據庫快照是一個數據庫的只讀副本,它是數據庫所有數據的映射,由快照被執行的時間點來決定它的內容。

  這些數據庫快照在報表方面是非常有價值,因為在快照數據庫中或者在原數據庫中,對于任何查詢而言沒有鎖就將被執行?煺找部梢允褂迷跒碾y恢復中,因為你可以將現有的數據恢復到現有的快照中,或者還可以在有害數據操作聲明的事件中存儲個別必要的表和數據。

  數據庫快照是如何工作的?

  可以使用典型的數據庫命令CREATE DATABASE語句來生成一個數據庫快照,在聲明中有一個源數據庫快照的附加說明。當快照被建立時,同時生成一個稀疏文件。這個文件(只能使用在NTFS卷中)在初始化的時候并沒有磁盤空間分配給它——盡管你可能在WINDOWS資源管理器中看到了文件的大小,它會看上去與原始的源數據庫文件的大小相同。對磁盤來說其實這個文件的大小接近于零。

  數據庫快照在初始化時讀的數據文件是來自于源數據庫的。當源數據庫的數據發生變化時,數據引擎就會將原始數據從源數據庫拷貝到快照數據庫中。這個技術確?煺諗祿䦷熘环从晨煺毡粓绦袝r數據的狀態。當SELECT命令被用來發布反對數據庫快照時,不管數據頁的讀取是否被定位在源數據庫數據文件中還是在快照數據庫數據文件中都是沒有鎖被發布的。因為在只讀數據庫快照中是沒有鎖被發布,數據庫快照對于報表解決方案是一個重要的解決方案。

  一個快照的實例

  現在,讓我們來看看數據庫快照在SQL Server 2005中是如何工作的。為此,首先我需要一個源數據庫作為快照的來源。下面的腳本將創建一個源數據庫:USE master
GO
IF EXISTS(SELECT name from sysdatabases where [name] = 'SourceDatabase')
DROP DATABASE SourceDatabase
GO
CREATE DATABASE SourceDatabaseON PRIMARY
(
NAME = SourceDatabase_Data,
FILENAME = 'C:SQLServerSourceDatabase_Data.mdf'
) LOG ON
(
NAME = SourceDatabase_Log,
FILENAME = 'C:SQLServerSourceDatabase_Log.ldf'
)
GO
關鍵字: DataGuard checkpoint 動態查詢 synonyms 卸載SQL 2005 SQL Server群集
本文詳細介紹利用SQL Server數據庫快照形成報表

  注意這里產品區域的大小。我定義它的大小為CHAR(150)來強調數據文件的增長級數,這樣在我接下來的實例中將更容易解釋清楚快照是如何工作的。

  現在既然我已經有了一個源數據庫,現在我裝載一些數據來擴展數據文件的大小位。如此,使用列表1中的腳本來創建銷售歷史表。USE SourceDatabase
GO
IF OBJECT_ID('SalesHistory')>0   DROP TABLE SalesHistory
GO
CREATE TABLE SalesHistory
(   SaleID INT IDENTITY(1,1),  
Product CHAR(150),    SaleDate DATETIME,   
SalePrice MONEY
)
DECLARE @i INT
SET @i = 1
WHILE (@i <=10000)
BEGIN   INSERT INTO SalesHistory   (Product, SaleDate, SalePrice)   
VALUES   ('Computer', DATEADD(mm, @i, '3/11/1919'),
DATEPART(ms, GETDATE()) + (@i + 57) )
   INSERT INTO SalesHistory   (Product, SaleDate, SalePrice)   
VALUES   ('BigScreen', DATEADD(mm, @i, '3/11/1927'),
DATEPART(ms, GETDATE()) + (@i + 13) )
   INSERT INTO SalesHistory   (Product, SaleDate, SalePrice)   
VALUES   ('PoolTable', DATEADD(mm, @i, '3/11/1908'),
DATEPART(ms, GETDATE()) + (@i + 29) )
   SET @i = @i + 1
END
GO

  列表1

  一旦你運行以下的腳本,就可以來操縱數據庫文件儲存的地方了。在這個實例上面,我將這些文件放在C:SQL Server文件夾下。在我的計算機上,當數據庫被初始化創建時數據文件的大小是1,216KB,數據裝載后的大小是7,360KB。既然源數據庫有一些數據已經在里面了,所以我們現在就能建立一個快照了。使用以下的腳本來建立數據庫快照。CREATE DATABASE SnapshotDatabase
ON
(
NAME = 'SourceDatabase_Data',
FILENAME = 'C:SQLServerSnapshotDatabase.mdf'
) AS SNAPSHOT OF SourceDatabase
關鍵字: DataGuard checkpoint 動態查詢 synonyms 卸載SQL 2005 SQL Server群集
本文詳細介紹利用SQL Server數據庫快照形成報表

  這個創建快照的語法與創建數據庫的語法非常相似。兩個主要的區別:第一個區別是AS SNAPSHOT OF SourceDatabase語句,在服務器實例上指明哪個數據庫將作為快照的源數據庫;第二個區別是,在事實上數據庫快照是不會生成日志文件的。因為沒有數據操作事物只會發生在只讀數據庫上,所以沒有也不需要日志。

  這個數據庫腳本創建一個名為SnapshotDatabase.mdf(數據文件的擴展名不需要mdf)的稀疏文件。如果你在WINDOWS資源管理器中操作這個文件,并同時查看它的屬性,你將看到這個文件的大小與源數據庫文件的大小相同;然而,實際上磁盤上的大小卻接近于零。這時,數據庫快照是沒有它自己的數據。

  你能運行上面我使用的腳本重新在SourceDatabase數據庫里面插入10,000行數據到SalesHistory表中。這時,我的SourceDatabase數據庫大小是12,480KB,同時,磁盤上我的SourceDatabase數據庫大小現在為448KB。這時在SourceDatabase數據庫中所改變的數據頁都已經被拷貝到SnapshotDatabase數據庫中了,這樣就能解釋為什么在磁盤上它的大小被增加了。

  進一步思考

  數據庫快照允許你為報表創建只讀數據庫,并且如果有必要的話你可以恢復你的源數據庫到你的數據庫快照上。同樣的,你也可以根據你的報表目的創建任意多個數據庫快照。

  特別值得注意的是,這些數據庫快照會占用磁盤空間,如果有太多的數據庫快照的話,它將很快的將你的磁盤陣列填滿,尤其在一個產品環境下,如果數據經常要被更新,就更容易將磁盤陣列填滿。

  另外,使用數據庫快照會降低數據庫的性能,因為在數據庫中將數據頁作為執行寫操作拷貝是增加了數據庫輸入/輸出。

  雖然有這些小缺點,如果你能為報表提出一個好的數據庫快照創建方案,SQL Server 2005的這個新的特性將有更多的人使用。
關鍵字:SQL Server、數據庫、快照、報表
分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站