SQL Server 2008 FileStream支持“真功夫版”

数据库 SQL Server
以下的文章主要是浅谈SQL Server 2008 FileStream支持,愿在你学习SQL Server 2008 FileStream支持中以起到抛砖引玉的作用。

文章主要描述的是SQL Server 2008 FileStream支持,你如果对SQL Server 2008 FileStream支持有兴趣的话你就可以点击以下的文章进行观看了,你如果对其有兴趣的话你就可以点击以下的文章进行观看了。

服务器有一个属性,即指定该服务器是怎么支持文件流的

实际上文件流的出现就是为了解决对大对象的存储中一个矛盾。

对于大对象,第一种方式是存储在数据库里面,这种方式一般使用image字段,或者varbinary(max)来做。好处是可以统一备份,但实际上读取效率比较低。大于1MB的文件就会有问题

第二种方式是文件存储在文件系统,而数据库中存储了一个路径。这种方式数据库压力减轻了,却很不方便统一备份和管理。

SQL SERVER 2008的文件流其实就是二者的统一。文件还是放在文件系统的,但由数据库进行管理。可以统一备份和还原。

FILESTREAM不是一个字段类型,它定义在字段后面,声明该列用于文件流即可。该列依然是用二进制保存的

一般都是在数据库中要特别添加一个文件组和一个或多个文件用来存储FileStream的数据的。

然后,在磁盘上面有一个目录(Test),里面会有一个filestream.hdr文件

客户端是透明的。无需要什么修改。

*/

这段代码的作用是启用服务器支持文件流

 

  1. EXEC sp_filestream_configure  
  2. @enable_level = 3;  
  3. CREATE DATABASE Archive  
  4. ON  
  5. PRIMARY ( NAME = Arch1,  
  6. FILENAME = 'c:labarchdat1.mdf'),  
  7. FILEGROUP FileStreamGroup1 CONTAINS FILESTREAM( NAME = Arch3,  
  8. FILENAME = 'c:labfilestream1')  
  9. LOG ON ( NAME = Archlog1,  
  10. FILENAME = 'c:labarchlog1.ldf')  
  11. GO  
  12. CREATE TABLE Archive.dbo.Records  
  13. (  
  14. [Id] [uniqueidentifier] ROWGUIDCOL NOT NULL UNIQUE,  
  15. [SerialNumber] INTEGER UNIQUE,  
  16. [Chart] VARBINARY(MAX) FILESTREAM NULL  

这一句指示该列要用文件流存储

这里还可以做一些改进,就是加入文件类型的一个字段(FileName)

 

 

  1. )  
  2. FILESTREAM_ON FileStreamGroup1   

 

该行指示存储到哪一个文件流文件组

 

GO

 

下面代码无法运行,如果一个表要使用文件流,则必须有一个GUID列,而且作为唯一键列

 

  1. CREATE TABLE Archive.dbo.Records2  
  2. (  
  3. --[Id] [uniqueidentifier] ROWGUIDCOL NOT NULL UNIQUE,  
  4. [SerialNumber] INTEGER UNIQUE,  
  5. [Chart] VARBINARY(MAX) FILESTREAM NULL 

--这一句指示该列要用文件流存储

)

 

FILESTREAM_ON FileStreamGroup1 --该行指示存储到哪一个文件流

 

  1. GO  
  2. INSERT INTO Archive.dbo.Records  
  3. VALUES (newid (), 1, NULL);  
  4. GO  
  5. INSERT INTO Archive.dbo.Records  
  6. VALUES (newid (), 2,  
  7. CAST ('' as varbinary(max)));  
  8. GO  
  9. INSERT INTO Archive.dbo.Records  
  10. VALUES (newid (), 3,  
  11. CAST ('Seismic Data' as varbinary(max)));  
  12. GO  
  13. UPDATE Archive.dbo.Records  
  14. SET [Chart] = CAST('Xray 1' as varbinary(max))  
  15. WHERE [SerialNumber] = 2;  
  16. DELETE Archive.dbo.Records  
  17. WHERE SerialNumber = 1;  
  18. GO  
  19. SELECT * FROM Archive.dbo.Records  
  20. GO 

对于客户端编程来说,是没有区别的,这只是服务器的一个存储改变

保存

 

保存音乐文件

  1. try  
  2. {  
  3. OpenFileDialog dialog = new OpenFileDialog();  
  4. dialog.Filter = "音乐文件(*.mp3)|*.mp3";  
  5. if (dialog.ShowDialog() == DialogResult.OK)  
  6. {  
  7. using (SqlConnection conn = new SqlConnection(CONNECTIONSTRING)) {  
  8. conn.Open();  
  9. using (SqlCommand cmd = conn.CreateCommand()) {  
  10. cmd.CommandText = "INSERT INTO BINARYTABLE(BINARYCONTENTS) VALUES(@file)";  
  11. FileStream fs = new FileStream(dialog.FileName, FileMode.Open);  
  12. byte[] bytes = new byte[fs.Length];  
  13. fs.Read(bytes, 0, bytes.Length);  
  14. SqlParameter param = new SqlParameter("@file", SqlDbType.VarBinary,1000000);  
  15. param.Value = bytes;  
  16. cmd.Parameters.Add(param);  
  17. MessageBox.Show(cmd.ExecuteNonQuery() == 1 ? "成功保存文件" : "保存文件失败");  
  18. fs.Close();  
  19. }  
  20. conn.Close();  
  21. }  
  22. }  
  23. else  
  24. MessageBox.Show("用户取消了操作");  
  25. }  
  26. catch (Exception ex)  
  27. {  
  28. MessageBox.Show(ex.Message);  

读取

读取音乐文件

  1. try  
  2. {  
  3. using (SqlConnection conn = new SqlConnection(CONNECTIONSTRING)) {  
  4. conn.Open();  
  5. using (SqlCommand cmd = conn.CreateCommand()) {  
  6. cmd.CommandText = "select top 1 BinaryContents from BinaryTable order by ID desc";  
  7. SqlDataReader reader = cmd.ExecuteReader();  
  8. SaveFileDialog dialog = new SaveFileDialog();  
  9. dialog.Filter = "音乐文件(*.mp3)|*.mp3";  
  10. if (dialog.ShowDialog() == DialogResult.OK)  
  11. {  
  12. reader.Read();  
  13. System.Data.SqlTypes.SqlBinary result = reader.GetSqlBinary(0);//值得注意的是这里并没有什么GetSqlImage的方法  
  14. FileStream fs = new FileStream(dialog.FileName, FileMode.Create);  
  15. fs.Write(result.Value, 0, result.Length);  
  16. fs.Close();  
  17. reader.Close();  
  18. }  
  19. else  
  20. MessageBox.Show("用户取消操作");  
  21. }  
  22. conn.Close();  
  23. }  
  24. }  
  25. catch (Exception ex) { MessageBox.Show(ex.Message); } 

以上的相关内容就是对SQL Server 2008 FileStream支持的介绍,望你能有所收获。

【编辑推荐】

  1. SQL Server2000连接错误的缘由有哪些?
  2. SQL Server实例中对另个实例的调用
  3. SQL Server identity列,美中不足之处
  4. SQL Server DateTime数据类型的另类解读
  5. SQL Server 2000的安全策略的正确打造

 

责任编辑:佚名 来源: 清华大学出版社
相关推荐

2009-02-24 13:15:22

FILESTREAM新特性SQL Server

2009-02-25 11:42:43

FILESTREAM文件流文件管理

2010-11-15 11:25:20

职场

2011-08-29 18:02:29

SQL Server FileStream

2011-04-22 16:24:05

ME OFFICE 6爱普生传真

2009-10-13 15:43:03

网络拓扑管理

2010-11-09 16:03:27

2011-10-05 20:57:31

复合一体机常见问题

2011-12-07 13:21:42

超云服务器云计算

2009-09-08 14:45:24

Linq to SQL支持SQL Serve

2009-04-16 17:55:15

扩展热插拔SQL Server

2018-07-09 16:03:23

AI教育人工智能

2011-03-28 16:39:41

SQL Server

2010-07-22 14:52:00

SQL Server

2009-08-12 09:19:26

SQL Server

2011-03-29 12:42:25

SQL Server 高效性

2009-04-16 17:34:19

2009-04-16 18:15:19

动作审核审核活动SQL Server

2010-03-23 09:52:23

SQL Server

2009-04-16 17:44:31

点赞
收藏

51CTO技术栈公众号