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

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

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

文章主要描述的是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://www.2345hao.cn/blog/index.php/post/21931.html

分享给朋友:

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

各个都很实用:windows 7系统电脑日常小技巧

各个都很实用:windows 7系统电脑日常小技巧

在使用Windows 7的时候很多用户对于系统的很多功能并不是很了解,也正是因为这样的不了解导致很多用户在使用Win 之后并不能体验Windows 7的功能便携和强大功能,导致很多用户对于Windows 7的认识还是比较模糊,不过为了让更多的朋友了解Windows 7的特点和便携应用,今天就为大家汇...

windows 7系统怎么取消禁ping命令?

windows 7系统怎么取消禁ping命令?

当我在虚拟机的linux系统中ping本机的ip发现ping不通,而本机可以ping通虚拟机中的ip。应该是出于安全考虑吧,Windows 7默认在防火墙里禁止了。 1、查看主机ip 打开“开始”程序中的“附件”,找到“命令提示符”打开。输入命令:ipconfig,可以看到本机的ip是192.1...

windows 7系统下Windows服务被流氓软件注册怎么办?Windows服务

windows 7系统下Windows服务被流氓软件注册怎么办?Windows服务

解决方法: 其实处理这些使用流氓软件,需要将相关的.exe文件删除,使它不能再运行,或者直接清除这个服务本身,使计算机重启的时候,它不会再启动。比如Hijackthis扫描,在扫描日志中,一般会把非Windows系统的服务以023的方式列出来,如下面这段: O23 - ...

windows 7怎么设置密码永不过期?

windows 7怎么设置密码永不过期?

下面小编以Windows 7 64位为例,介绍下密码是如何设置永不过期的。  1、在桌面上打开“开始”菜单,或者点击“Win+R”快捷键将“运行”对话框打开。  2、运行对话框打开后,在里面中输入“lusrmgr.msc”字符命令,就可以打开“本地用户和组程序”。...

Ubuntu系统上挂载U盘和Windows分区问题的解决实例

Ubuntu系统上挂载U盘和Windows分区问题的解决实例

Ubuntu挂载U盘问题 复制代码代码如下: 老是说special device /dev/sdb1 does not exist,无比郁闷 复制代码代码如下:#fdisk /dev/sda 复制代码代码如下: 是有个 这个咚咚。。。。 复制代码代码如下: 最后: 复制代码代码如下:...

windows 7任务栏快捷方式如何居中显示默认从左像右排列

windows 7任务栏快捷方式如何居中显示默认从左像右排列

使用Windows 7的朋友都知道,任务栏上的快捷方式图标都是靠近开始菜单按钮,从左像右排列,不过也有一些用户喜欢左右对称,想要把那些快捷方式居中显示,看起来这个任务好像无从下手,其实一点也不难,只要通过下面方法就能轻松搞定。 1、首先在电脑磁盘中任何一个地方新建一个文件夹。 2、右击任务栏-&...