在 Sql Server 中启用 DTD 支持

Enabling DTD support in Sql Server(在 Sql Server 中启用 DTD 支持)

本文介绍了在 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 支持

基础教程推荐