时间:2021-05-02
误区 #18:如下多个有关FileStream的误区
全部错误
18 a)FileStream数据可以在远程存储
不能,由于FileStream数据容器(指的是存放FileStream文件的NTFS文件夹,杜撰出来的术语)必须像数据文件或日志文件那样符合本地存储策略-也就是说,这个数据容器必须放在对于运行SQL Server的Windows Server是本地存储(译者注:也就是在‘计算机'里能看到的存储,DAC当然是了,其实SAN这类不直接连接服务器的也算是)访问FileStream数据只要客户端连接到了SQL Server服务器并获取响应的事务上下文后,就可以通过UNC路径进行访问了。
18 b)FileStream的数据容器可以嵌套
不能,对于同一个数据库的两个不同的FileStream容器可能在同一个目录下,但是却不能嵌套。而对于不同数据库的FileStream容器无法在同一个目录下。我的一篇博文有一段代码能说明这一点:Misconceptions around FILESTREAM storage。
18 c)对于FileStream的更新可以部分更新
对于任何FileStream的更新都会导致创建一个全新的FileStream文件,这个操作会被日志原原本本的记录下来。这也就是为什么FileStream不能被用于数据库镜像。这么多数据如果用于镜像的话那后果简直不可想象,只能希望未来的SQL Server版本可以修改这种机制以允许部分更新。
18 d)FileStream会在不需要的时候立刻被垃圾回收
错误。FileStream数据会在不再需要并且到了下一个Checkpoint的时候进行垃圾回收。这点并不是那么直接以至于很多人对FileStream的回收机制存在误区。
18 f)FileStream存放的目录以及文件名是随机取得
其实不然,FileStream的文件名其实代表的是创建其操作对应LSN号。表和列的GUID目录名是可以在系统表中获取到。
我下面两篇博文对此有了更详细的解释:
FILESTREAM directory structure 解释了如何从一个FileStream所在行来得知其名称
FILESTREAM directory structure - where do the GUIDs come from? 可以望文生义的知道这篇文章所讲述的内容:-)
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
误区#18:如下多个有关FileStream的误区全部错误18a)FileStream数据可以在远程存储不能,由于FileStream数据容器(指的是存放Fil
垃圾回收机制垃圾回收机制是一种动态存储分配方案。它会自动释放程序不再需要的已分配的内存块。自动回收内存的过程叫垃圾收集。垃圾回收机制可以让程序员不必过分关心程序
Java垃圾回收与对象生命周期详解Java中的垃圾回收与对象生命周期1.垃圾回收垃圾回收是Java程序设计中内存管理的核心概念,JVM的内存管理机制被称为垃圾回
售前服务推荐原因:1.垃圾分类回收,整桶能够分为3个一部分,各自储放干垃圾,湿垃圾,可回收。PS:7月起上海市逐渐强制性垃圾分类回收,全国各地也会迅速的普及化,
5月1日开始,新修订的《北京市生活垃圾管理条例》开始实施。据了解,北京版垃圾分类采取“四分法”:有害垃圾、可回收物、厨余垃圾、其他垃圾。