博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[SQLServer大对象]——FileTable从文件系统迁移文件
阅读量:5226 次
发布时间:2019-06-14

本文共 2039 字,大约阅读时间需要 6 分钟。

阅读导航

从文件系统中迁移文件到FileTable

批量加载文件到FileTable

如何批量加载文件到FileTable

 

通过博文,已经可以将文件加载到数据库中,并查看和访问这些文件。

将文件加载到 FileTable,可以使用工具xcopy或robocopy,也可以自己编写脚本(如PowerShell)或者应用程序,复制文件到FileTable中。

现在说一说文件的迁移。

 

从文件系统中迁移文件到FileTable

迁移文件条件

    文件存储在文件系统中

    在 SQL Server 中元数据的表包含一个指向文件的指针

执行前提

要将文件迁入到 FileTable,需要将每一个文件的原始UNC路径用FileTable的UNC路径代替。

现在我们假定现有 FileTable PhotoMetadata 包含图片数据,。这个表有一个varchar(512)类型的UNC路径列,其中包含执行.jpg文件的实际路径。

将.jpg及其目录结构一起复制到FileT的根目录下。

执行

使用代码修改 PhotoMetadata 的元数据:

1:  --  添加一个路径定位器到 PhotoMetadata。
2:  ALTER TABLE PhotoMetadata ADD pathlocator hierarchyid;
3:   
4:  -- 获得在文件系统中图片的根路径。
5:  DECLARE @UNCPathRoot varchar(100) = '\\RemoteShare\Photographs';
6:   
7:  -- 获得FileTable的根路径。
8:  DECLARE @FileTableRoot varchar(1000);
9:  SELECT @FileTableRoot = FileTableRootPath('dbo.PhotoTable');
10:   
11:  -- 更新PhotoMetadata。
12:   
13:  -- 使用 FileTable 路径代替文件系统 UNC 路径。
14:  UPDATE PhotoMetadata
15:      SET UNCPath = REPLACE(UNCPath, @UNCPathRoot, @FileTableRoot);
16:   
17:  -- 更新 FileTable 的 pathlocator 列。
18:  UPDATE PhotoMetadata
19:      SET pathlocator = GetPathLocator(UNCPath);

批量加载文件到FileTable

对于批量操作,FileTable和其他表基本一样,但是有些需要注意的地方。

FileTable有系统定义的约束,这些约束是为了确保文件的完整性和目录空间具有可维护性。这些约束验证数据批量加载到FileTable中。由于一些大量插入操作允许忽略表约束,所以接下来的是被强制要求的。

    强制约束的批量加载操作可以像在任何其他表一样在 FileTable使用,具体操作如下:

        bcp 带 CHECK_CONSTRAINTS 子句。

        BULK INSERT 带 CHECK_CONSTRAINTS 子句。

        INSERT INTO … SELECT * FROM OPENROWSET(BULK …) 不带 IGNORE_CONSTRAINTS 子句。

    非强制约束的批量加载操作会失败,除非 FileTable 系统定义的约束已禁用,具体操作如下:

        bcp 不带 CHECK_CONSTRAINTS 子句。

        BULK INSERT 不带 CHECK_CONSTRAINTS 子句。

        INSERT INTO … SELECT * FROM OPENROWSET(BULK …) 带 IGNORE_CONSTRAINTS 子句。

 

如何批量加载文件到FileTable

可以使用多种方法批量加载文件到FileTable:

    bcp

        使用 CHECK_CONSTRAINTS 子句。

        禁用FileTable命名空间,并且不使用 CHECK_CONSTRAINTS 子句。然后重新启用FileTable命名空间。

    BULK INSERT

        使用 CHECK_CONSTRAINTS 子句。

        禁用FileTable命名空间,并且不使用 CHECK_CONSTRAINTS 子句。然后重新启用FileTable命名空间

    INSERT INTO … SELECT * FROM OPENROWSET(BULK …)

        使用 CHECK_CONSTRAINTS 子句。

        禁用FileTable命名空间,并且不使用 CHECK_CONSTRAINTS 子句。然后重新启用FileTable命名空间

转载于:https://www.cnblogs.com/BoyceYang/p/3175610.html

你可能感兴趣的文章
oracle中anyData数据类型的使用实例
查看>>
C++对vector里面的元素排序及取任意重叠区间
查看>>
蓝桥杯题——包子凑数
查看>>
软件测试——性能测试总结
查看>>
sky1301测试总结 just before chip comes back
查看>>
12.4站立会议
查看>>
Sequelize为什么需要使用Migrations
查看>>
React.js 小书 Lesson22 - props.children 和容器类组件
查看>>
在Js中得到元素的子元素集合注意事项
查看>>
Spring MVC之DispatcherServlet初始化详解
查看>>
多线程篇-GCD-基本概念使用
查看>>
生成唯一的随机数
查看>>
尼玛某前辈把ant 工程 改成android studio工程然后上传了 对我来说 尼玛这玩意就和屎一样...
查看>>
SSM整合(精简版)
查看>>
各种xml文件约束,Eclipse用
查看>>
泰勒展开,傅里叶变换,拉普拉斯变换和Z变换的物理意义
查看>>
Java Concurrentmodificationexception异常原因和解决方法
查看>>
Python 面向对象(其四)
查看>>
客户端访问浏览器的流程
查看>>
Linux——ls
查看>>