在 Sql Server 中启用 DTD 支持 [英] Enabling DTD support in Sql Server

查看:22
本文介绍了在 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 支持的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆