SQL Server FileStream詳解_MsSql

來源:互聯網
上載者:User

FILESTREAM是SQL Server 2008中的一個新特性,允許以獨立檔案的形式存放大對象資料,而不是以往一樣將所有資料都儲存到資料檔案中。以往在對業務系統的檔案進行管理時有兩種方法,一種是將檔案儲存到伺服器檔案系統中,資料庫中只儲存了該檔案的路徑,在使用該檔案時應用程式串連到伺服器讀取檔案;另一種是將檔案以varbinary(max)或image資料類型儲存到SQL Server中。而SQL Server 2008提供了FILESTREAM,結合這兩種方式的優點。

FILESTREAM使SQL Server資料庫引擎和NTFS檔案系統成為了一個整體。Transact-SQL語句可以插入、更新、查詢、搜尋和備份FILESTREAM資料。FILESTREAM使用NT系統緩衝來快取檔案資料。這有助於減少FILESTREAM資料可能對資料庫引擎效能產生的任何影響。由於沒有使用SQL Server緩衝池,因此該記憶體可用於查詢處理。

以往我們對檔案管理有兩種方法:

 1.資料庫只儲存檔案的路徑,具體的檔案儲存在檔案伺服器(NFS)上,使用時,編程實現從檔案伺服器讀取檔案;

 2.將檔案直接以varbinary(max)或image資料類型儲存在資料庫中。

  上面兩種檔案存放方式都有問題:第一種方法因為會訪問磁碟,故受I/O影響效能不是很好,而且不能很好的進行檔案備份;第二種方法雖然解決了檔案備份(資料庫的備份)問題,但是由於欄位的位元組數太大,對資料庫本身也會造成影響,效能也很低下。

  微軟在SQL Server 2008推出了一種新的方式 - FileStream,它不是一種新的資料類型,而是一種技術,它使SQL Server資料庫引擎和NTFS檔案系統成為了一個整體,它結合了上面兩種方式的優點:FileStream使用NT系統來快取檔案資料,而對檔案資料的操作可使用Transact-SQL語句對其進行插入、更新、查詢、搜尋和備份。

一、FileStream配置

 1.配置SQL Server安裝執行個體:Start -> All Programs -> Microsoft SQL Server 2008 R2 -> Configuration Tools -> SQL Server Configuration Manager

 

右擊屬性,切換到FILESTREAM標籤,勾選如下配置

 

2. 開啟SQL Server,並配置如下 


   以上也可以通過如下指令碼執行:

Exec sp_configure filesteam_access_level, 2RECONFIGURE 

  最後重啟SQL Server Service

 

二、執行個體展示

  建立FileStream類型檔案/組

--Create filestreamgroup ALTER DATABASE [Archive]ADD FILEGROUP [FileStreamGroup] CONTAINS FILESTREAM GO--Create filestream and association with filestreamgroup aboveALTER DATABASE [Archive]ADD FILE ( NAME = N'FileStream', FILENAME = N'D:\Company\Data\SQL Server\FileStream') TO FILEGROUP [FileStreamGroup]GO

  建立測試表(注意:如果表包含FILESTREAM列,則每一行都必須具有唯一的行ID)

--Create tableCREATE TABLE Archive.dbo.Attachment (  [ID] [UNIQUEIDENTIFIER] ROWGUIDCOL NOT NULL PRIMARY KEY,  [FileName] NVARCHAR(100) NULL,  [CreateUser] NVARCHAR(100) NULL,  [CreateDatetime] DATETIME NULL,  [Content] VARBINARY(MAX) FILESTREAM NULL )FILESTREAM_ON [FileStreamGroup] 

  插入一些測試資料

 --Insert some recordsINSERT INTO Attachment VALUES (NEWID(),'File Name 1','shg.cpan', GETDATE(),NULL),(NEWID(),'File Name 1','shg.cpan', GETDATE(),CAST('' AS VARBINARY(MAX))),(NEWID(),'File Name 1','shg.cpan', GETDATE(),CAST('This is a attachment, which contains all introduction for filestream' AS VARBINARY(MAX))) 

  從前台插入一些資料

using (SqlConnection conn = new SqlConnection("server=10.7.15.172;database=Archive;uid=sa;pwd=1234;Connect Timeout=180")){  conn.Open();  using (SqlCommand cmd = conn.CreateCommand())  {    string id = Guid.NewGuid().ToString();    cmd.CommandText = "INSERT INTO Attachment VALUES('" + id + "','File Name 2','shg.cpan','" + DateTime.Now + "',@content)";    SqlParameter param = new SqlParameter("@content", SqlDbType.VarBinary, 1000000000);    param.Value = File.ReadAllBytes(@"D:\Folder\131 u_ex151207.log");    cmd.Parameters.Add(param);    cmd.ExecuteNonQuery();  }  conn.Close();}

  檢索資料 

SELECT DATALENGTH(CONTENT)/(1024.0 * 1024.0) AS MB,* FROM ATTACHMENT  

結果

 

  檔案系統

  

   上面的檔案都是上傳的真實檔案,只不過沒有尾碼,如果重新命名加上尾碼,即可讀取,如最後一個是excel檔案,加上.xls,即可用Excel軟體開啟此檔案

三、注意事項

  請注意以下事項:

 •並不是所有的檔案儲存體都適合使用FileStream,如果所儲存的檔案對象平均大於1MB考慮使用FileStream,否則對於較小的檔案對象,以varbinary(max)BLOB儲存在資料庫中通常會提供更為優異的流效能;
 •FileStream可以使用在故障叢集上(Failover Cluster),但此時FileStream檔案組必須位於共用磁碟資源上;
 •FILESTREAM 與其他 SQL Server 功能的相容性:https://msdn.microsoft.com/zh-cn/library/bb895334(v=sql.105).aspx

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.