Enabling DTD support in Sql Server(在 Sql Server 中启用 DTD 支持)
问题描述
我有各种 xml 文档需要存储在数据库列中.这些文档包含对 DTD 的引用,并且 SQL Server 不会导入 xml,因为它存在安全风险.如何在数据库上启用 DTD 支持,以便我插入 xml 内容.
I have various xml documents that I need to store in a database column. The documents contain references to a DTD and SQL Server won't import the xml because it is a security risk. How can I enable DTD support on the database so it will let me insert the xml content.
推荐答案
你必须先CONVERT
.
MSDN一个>:
您可以使用以下命令从包含 DTD 的数据文件中导入 XML 数据OPENROWSET(BULK...) 函数,然后指定 CONVERT命令的 SELECT 子句中的选项.的基本语法命令是:
you can import XML data from a data file that contains a DTD by using the OPENROWSET(BULK...) function and then specifying the CONVERT option in the SELECT clause of the command. The basic syntax for the command is:
INSERT ... SELECT CONVERT(...) FROM OPENROWSET(BULK...)
示例:
INSERT T1
SELECT CONVERT(xml, BulkColumn, 2) FROM
OPENROWSET(Bulk 'c:\temp\Dtdfile.xml', SINGLE_BLOB) [rowsetresults];
这篇关于在 Sql Server 中启用 DTD 支持的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在 Sql Server 中启用 DTD 支持
基础教程推荐
- SQL Server:只有 GROUP BY 中的最后一个条目 2021-01-01
- Sql Server 字符串到日期的转换 2021-01-01
- SQL Server 中单行 MERGE/upsert 的语法 2021-01-01
- 使用pyodbc“不安全"的Python多处理和数据库访问? 2022-01-01
- ERROR 2006 (HY000): MySQL 服务器已经消失 2021-01-01
- 如何在 SQL Server 的嵌套过程中处理事务? 2021-01-01
- 将数据从 MS SQL 迁移到 PostgreSQL? 2022-01-01
- SQL Server 2016更改对象所有者 2022-01-01
- 无法在 ubuntu 中启动 mysql 服务器 2021-01-01
- 在 VB.NET 中更新 SQL Server DateTime 列 2021-01-01