位置: 编程技术 - 正文

SQL Server FileStream详解

编辑:rootadmin

推荐整理分享SQL Server FileStream详解,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

FILESTREAM是SQL Server 中的一个新特性,允许以独立文件的形式存放大对象数据,而不是以往一样将所有数据都保存到数据文件中。以往在对业务系统的文件进行管理时有两种方法,一种是将文件保存到服务器文件系统中,数据库中只保存了该文件的路径,在使用该文件时应用程序连接到服务器读取文件;另一种是将文件以varbinary(max)或image数据类型保存到SQL Server中。而SQL Server 提供了FILESTREAM,结合这两种方式的优点。

FILESTREAM使SQL Server数据库引擎和NTFS文件系统成为了一个整体。Transact-SQL语句可以插入、更新、查询、搜索和备份FILESTREAM数据。FILESTREAM使用NT系统缓存来缓存文件数据。这有助于减少FILESTREAM数据可能对数据库引擎性能产生的任何影响。由于没有使用SQL Server缓冲池,因此该内存可用于查询处理。

以往我们对文件管理有两种方法:

1.数据库只保存文件的路径,具体的文件保存在文件服务器(NFS)上,使用时,编程实现从文件服务器读取文件;

2.将文件直接以varbinary(max)或image数据类型保存在数据库中。

  上面两种文件存放方式都有问题:第一种方法因为会访问磁盘,故受I/O影响性能不是很好,而且不能很好的进行文件备份;第二种方法虽然解决了文件备份(数据库的备份)问题,但是由于字段的字节数太大,对数据库本身也会造成影响,性能也很低下。

  微软在SQL Server 推出了一种新的方式 - FileStream,它不是一种新的数据类型,而是一种技术,它使SQL Server数据库引擎和NTFS文件系统成为了一个整体,它结合了上面两种方式的优点:FileStream使用NT系统来缓存文件数据,而对文件数据的操作可使用Transact-SQL语句对其进行插入、更新、查询、搜索和备份。

一、FileStream配置

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

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

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

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

SQL Server FileStream详解

  最后重启SQL Server Service

二、实例展示

  创建FileStream类型文件/组

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

  插入一些测试数据

  从前台插入一些数据

  检索数据

结果

  文件系统

  

  上面的文件都是上传的真实文件,只不过没有后缀,如果重命名加上后缀,即可读取,如最后一个是excel文件,加上.xls,即可用Excel软件打开此文件

三、注意事项

  请注意以下事项:

&#;并不是所有的文件存储都适合使用FileStream,如果所存储的文件对象平均大于1MB考虑使用FileStream,否则对于较小的文件对象,以varbinary(max)BLOB存储在数据库中通常会提供更为优异的流性能; &#;FileStream可以使用在故障集群上(Failover Cluster),但此时FileStream文件组必须位于共享磁盘资源上; &#;FILESTREAM 与其他 SQL Server 功能的兼容性:

SQL Server中数据行批量插入脚本的存储实现 无意中看到朋友写的一篇文章将表里的数据批量生成INSERT语句的存储过程的实现。我仔细看文中的两个存储代码,自我感觉两个都不太满意,都是生成

将表里的数据批量生成INSERT语句的存储过程 增强版 有时候,我们需要将某个表里的数据全部或者根据查询条件导出来,迁移到另一个相同结构的库中目前SQLServer里面是没有相关的工具根据查询条件来生

SqlServer使用 case when 解决多条件模糊查询问题 我们在进行项目开发中,经常会遇到多条件模糊查询的需求。对此,我们常见的解决方案有两种:一是在程序端拼接SQL字符串,根据是否选择了某个条

标签: SQL Server FileStream详解

本文链接地址:https://www.jiuchutong.com/biancheng/312863.html 转载请保留说明!

上一篇:SQL Server中的RAND函数的介绍和区间随机数值函数的实现(sql随机函数rand怎么用)

下一篇:SQL Server中数据行批量插入脚本的存储实现(sql server中数据文件的扩展名是)

  • 房地产销售土地属于什么收入
  • 进项税额转出时点
  • 收到上月保险赔偿款分录
  • 借款利息抵扣土增
  • 开票地址开错有什么后果
  • 商贸公司可以做美容行业吗?
  • 英国租金收入所得税
  • 收到采购材料发票的会计分录
  • 拿到一个材料如何加工
  • 公司取出的备用金怎么打税
  • 审工资的流程
  • 人工费收税吗
  • 前期差错更正处理方法
  • 陕西省水利基金的税率
  • 关于不动产进项税额分期抵扣的新政策,以下不属于
  • 控股合并吸收合并新设合并图示
  • 预缴时少缴税款是否需要缴纳滞纳金?
  • 商品流通企业会计零售业务核算
  • 企业银行存款账户核算的内容有
  • 跨年多计提折旧的账务处理
  • 销售商品收到货款20000元存入银行
  • 工效挂钩企业工资税前扣除有何规定?
  • 企业注销后有收入怎么交税
  • 进销存账本怎么做
  • 股票溢价净收入计入
  • 苹果手机上传速度很慢
  • linux的ps命令用法
  • 冲销以前年度多计提的工资资产负债表怎么平
  • win10桌面图标怎么随意摆放
  • 年终奖发放问题
  • 谷歌浏览器插件中心
  • 马哈拉施特拉邦人口
  • 逾期未收回包装物押金增值税
  • php防止sql注入的方法
  • c++简易游戏
  • thinkphp模糊查询
  • hive.
  • 帝国cms移动端
  • 临时工交押金会扣钱吗
  • 网上报税教程
  • php运行乱码怎么办
  • mysql存二进制用哪个字段
  • 资产负债表中利息收入填在哪
  • 代缴纳房产税
  • 监控维护费用计入什么明细科目
  • 工会支付职工福利费做账
  • 收到政府补贴如何入账
  • 会计中管理费用和制造费用的区别
  • 完工产品成本计算表怎么填
  • 什么是年化收益和绝对利率
  • 归还银行的贷款会计分录
  • 出口退税进项税额转出怎么申报
  • 当月的增值税发票认证抵扣时间
  • 销售费用和管理费用的税前扣除
  • 固定资产处置如何申报企业所得税
  • 科目汇总表账务处理程序登记总账的依据是
  • 建筑升降机厂家
  • mysql m1
  • mysql 注入漏洞
  • winxp怎么打印
  • ubuntu ifdown
  • linux系统监控软件
  • centos6.7安装图形界面教程
  • xp软件自动启动
  • ssh远程连接linux
  • windowsxp服务在哪里
  • 邮件版本
  • Linux下通过script 命令记录(数据库)操作步骤
  • win10系统误删文件怎么恢复
  • 如何解决win7系统中鼠标键盘不能用
  • win8系统盘清理
  • linux文件压缩和备份实验
  • dirsearch批量
  • 页面抓取的流程是什么
  • Intent and Intent Filters
  • 深入浅出jquery
  • 增值税电子普通发票需要盖章吗
  • 个人所得税完税证明
  • 陈列费发票能抵扣吗
  • 城镇土地使用税优惠政策
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设