SQL Server中FileStream的作用是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

一、FileStream配置

1.配置SQL Server安装实例:Start -> All Programs -> Microsoft SQL Server 2008 R2 -> Configuration Tools -> SQL Server Configuration Manager

右击属性,切换到FILESTREAM标签,勾选如下配置

2. 打开SQL Server,并配置如下

  以上也可以通过如下脚本执行:

Execsp_configurefilesteam_access_level,2RECONFIGURE

  最后重启SQL Server Service

二、实例展示

  创建FileStream类型文件/组

--CreatefilestreamgroupALTERDATABASE[Archive]ADDFILEGROUP[FileStreamGroup]CONTAINSFILESTREAMGO--CreatefilestreamandassociationwithfilestreamgroupaboveALTERDATABASE[Archive]ADDFILE(NAME=N'FileStream',FILENAME=N'D:\Company\Data\SQLServer\FileStream')TOFILEGROUP[FileStreamGroup]GO

  创建测试表(注意:如果表包含FILESTREAM列,则每一行都必须具有唯一的行ID)

--CreatetableCREATETABLEArchive.dbo.Attachment([ID][UNIQUEIDENTIFIER]ROWGUIDCOLNOTNULLPRIMARYKEY,[FileName]NVARCHAR(100)NULL,[CreateUser]NVARCHAR(100)NULL,[CreateDatetime]DATETIMENULL,[Content]VARBINARY(MAX)FILESTREAMNULL)FILESTREAM_ON[FileStreamGroup]

  插入一些测试数据

--InsertsomerecordsINSERTINTOAttachmentVALUES(NEWID(),'FileName1','shg.cpan',GETDATE(),NULL),(NEWID(),'FileName1','shg.cpan',GETDATE(),CAST(''ASVARBINARY(MAX))),(NEWID(),'FileName1','shg.cpan',GETDATE(),CAST('Thisisaattachment,whichcontainsallintroductionforfilestream'ASVARBINARY(MAX)))

  从前台插入一些数据

using(SqlConnectionconn=newSqlConnection("server=10.7.15.172;database=Archive;uid=sa;pwd=1234;ConnectTimeout=180")){conn.Open();using(SqlCommandcmd=conn.CreateCommand()){stringid=Guid.NewGuid().ToString();cmd.CommandText="INSERTINTOAttachmentVALUES('"+id+"','FileName2','shg.cpan','"+DateTime.Now+"',@content)";SqlParameterparam=newSqlParameter("@content",SqlDbType.VarBinary,1000000000);param.Value=File.ReadAllBytes(@"D:\Folder\131u_ex151207.log");cmd.Parameters.Add(param);cmd.ExecuteNonQuery();}conn.Close();}

  检索数据

SELECTDATALENGTH(CONTENT)/(1024.0*1024.0)ASMB,*FROMATTACHMENT 

结果

  文件系统

  上面的文件都是上传的真实文件,只不过没有后缀,如果重命名加上后缀,即可读取,如最后一个是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

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。