当前位置:首页 > 系统运维 > 正文内容

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

a8116255316年前 (2010-07-13)系统运维7

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

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

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

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

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

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

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

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

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

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

*/

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

EXEC sp_filestream_configure  @enable_level = 3;  CREATE DATABASE Archive  ON  PRIMARY ( NAME = Arch1,  FILENAME = 'c:labarchdat1.mdf'),  FILEGROUP FileStreamGroup1 CONTAINS FILESTREAM( NAME = Arch3,  FILENAME = 'c:labfilestream1')  LOG ON ( NAME = Archlog1,  FILENAME = 'c:labarchlog1.ldf')  GO  CREATE TABLE Archive.dbo.Records  (  [Id] [uniqueidentifier] ROWGUIDCOL NOT NULL UNIQUE,  [SerialNumber] INTEGER UNIQUE,  [Chart] VARBINARY(MAX) FILESTREAM NULL  

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

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

)  FILESTREAM_ON FileStreamGroup1   

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

GO

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

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

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

)

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

GO  INSERT INTO Archive.dbo.Records  VALUES (newid (), 1, NULL);  GO  INSERT INTO Archive.dbo.Records  VALUES (newid (), 2,  CAST ('' as varbinary(max)));  GO  INSERT INTO Archive.dbo.Records  VALUES (newid (), 3,  CAST ('Sei *** ic Data' as varbinary(max)));  GO  UPDATE Archive.dbo.Records  SET [Chart] = CAST('Xray 1' as varbinary(max))  WHERE [SerialNumber] = 2;  DELETE Archive.dbo.Records  WHERE SerialNumber = 1;  GO  SELECT * FROM Archive.dbo.Records  GO 

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

保存

保存音乐文件

try  {  OpenFileDialog dialog = new OpenFileDialog();  dialog.Filter = "音乐文件(*.mp3)|*.mp3";  if (dialog.ShowDialog() == DialogResult.OK)  {  using (SqlConnection conn = new SqlConnection(CONNECTIONSTRING)) {  conn.Open();  using (SqlCommand cmd = conn.CreateCommand()) {  cmd.CommandText = "INSERT INTO BINARYTABLE(BINARYCONTENTS) VALUES(@file)";  FileStream fs = new FileStream(dialog.FileName, FileMode.Open);  byte[] bytes = new byte[fs.Length];  fs.Read(bytes, 0, bytes.Length);  SqlParameter param = new SqlParameter("@file", SqlDbType.VarBinary,1000000);  param.Value = bytes;  cmd.Parameters.Add(param);  MessageBox.Show(cmd.ExecuteNonQuery() == 1   "成功保存文件" : "保存文件失败");  fs.Close();  }  conn.Close();  }  }  else  MessageBox.Show("用户取消了操作");  }  catch (Exception ex)  {  MessageBox.Show(ex.Message);  

读取

读取音乐文件

try  {  using (SqlConnection conn = new SqlConnection(CONNECTIONSTRING)) {  conn.Open();  using (SqlCommand cmd = conn.CreateCommand()) {  cmd.CommandText = "select top 1 BinaryContents from BinaryTable order by ID desc";  SqlDataReader reader = cmd.ExecuteReader();  SaveFileDialog dialog = new SaveFileDialog();  dialog.Filter = "音乐文件(*.mp3)|*.mp3";  if (dialog.ShowDialog() == DialogResult.OK)  {  reader.Read();  System.Data.SqlTypes.SqlBinary result = reader.GetSqlBinary(0);//值得注意的是这里并没有什么GetSqlImage的 ***  FileStream fs = new FileStream(dialog.FileName, FileMode.Create);  fs.Write(result.Value, 0, result.Length);  fs.Close();  reader.Close();  }  else  MessageBox.Show("用户取消操作");  }  conn.Close();  }  }  catch (Exception ex) { MessageBox.Show(ex.Message); } 

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

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://2345hao.cn/blog/index.php/post/21931.html

分享给朋友:

“SQL Server 2008 FileStream支持“真功夫版”” 的相关文章

windows 7系统的电脑发出嘟嘟嘟的声音该怎么解决?

windows 7系统的电脑发出嘟嘟嘟的声音该怎么解决?

在某些电脑中,机器内部蜂鸣器与系统的声音输出方案是相关联的,这样一来会导致当系统输出声音时,即使电脑没有连接外部音响或耳机,也会通过内置蜂鸣器发出“嘟嘟哔哔”的声音。这个问题主要出现在Windows 7电脑中,假如你的电脑恰好遇到了这样的问题,可参考下面的方法来解决: 1、在桌面“计算机”图标上右...

windows 7系统件夹和文件都不显示名字如何解决

windows 7系统件夹和文件都不显示名字如何解决

假如碰到电脑里的文件夹和文件全都不显示名字了(如下图),是不是电脑中毒了呢 请教下笔者有没好的解决方法!下面是笔者给出的答案,希望能够帮助到大家! 首先打开你用来装图片的文件夹(缩略图下面的文字不显示的文件夹),然后但击工具栏上的“查看”选择“平铺”, 下面就是关键:要按住SHIFT键不...

Windows7截图出现黑屏导致截的图黑呼呼一片

Windows7截图出现黑屏导致截的图黑呼呼一片

最近一些Windows 7用户反馈说,自己在截屏的时候出现黑屏,导致自己截的图黑呼呼一片。这个问题该怎么解决?今天小编就为大家提供一个解决的方法。 步骤 1 在windows xp时代,很多用户都曾被视频截图后的“全黑图片”困扰。对此,在解决本地播放时出现的截图变黑问题,一般有两个方法可以用来解...

ubuntu14.04打开个几个应用窗口最小化后怎么切换呢?

ubuntu14.04打开个几个应用窗口最小化后怎么切换呢?

ubuntu14.04应用窗口列表在哪里?在ubuntu下打开个几个应用窗口最小化后怎么切换呢,应用窗口列表在哪里呢? 1、多打开几个chrome浏览器窗口。 2、然后都做最小化处理。 3、现在我们在桌面左边的面板上找到"左右两边有小白点"的chrome浏览器应用图标,这就是chr...

windows 7旗舰版系统提示应用程序错误代码0xc0000409的故障原因

windows 7旗舰版系统提示应用程序错误代码0xc0000409的故障原因

问题现象,具体如下所示:  故障分析: 一般来说,出现这种情况是因为电脑误删系统文件或者是系统文件被顽固木马破坏。       解决方法: 1、下载360安全卫士,找到里面的急救箱开始急救,然后进行修复,完成后重新启动; 2、下载瑞...

windows7系统下让所有文件夹都使用同一种视图的方法

windows7系统下让所有文件夹都使用同一种视图的方法

Windows 7系统可以对每个文件夹进行个性化视图设置,可以根据自己的个人喜好和实际需要更改文件或文件夹图标的大小,或者让文件或文件夹以列表、平铺等方式显示。但是,假如你对N个文件夹视图进行了风格各异的个性设置,现在又想让所有文件夹都使用同一种视图怎么办呢 手工一个一个修改,你OUT了,非累得手抽...