我在具有 10,000 条记录的表的 XML 类型列中有一个这样的 XML 层次结构-
<Root>
<Elem1>
<Parent1>
<Separator>
<Child1/>
</Separator>
</Parent1>
</Elem1>
</Root>
我有一个这样的查询 -
DECLARE @Root VARCHAR(50)
DECLARE @Entity VARCHAR(50)
DECLARE @ParentNode VARCHAR(50)
DECLARE @Separator VARCHAR(50)
DECLARE @ChildNode VARCHAR(50)
SET @Root = 'Root'
SET @Entity = 'Elem1'
SET @ParentNode = 'Parent1'
SET @Separator = 'separator'
SET @ChildNode = 'Child1'
select Parent.P.value('.', 'varchar(max)') as MyValue,
T.uniqueId, T.XMLCol
from [XMLTable] as T
cross apply
(SELECT
XMLTable.XMLCol.query('(/*[local-name()=sql:variable("@Root")]/*[local-name(.)=sql:variable("@Entity")]/*[local-name(.)=sql:variable("@ParentNode")]/*[local-name(.)=sql:variable("@Separator")]/*[local-name(.)=sql:variable("@ChildNode")])[1]'
) as Parent(P)
如何进一步优化此查询。目前,它需要 2 秒,如果我做进一步的 INNER JOINS,它会增加时间。我尝试在 XML 列上创建 PRIMARY 索引,但这需要更多时间!
编辑 - 如果我硬编码路径而不是使用变量,那么它需要不到一秒钟。但是,我希望它在表值函数中并且不能硬编码路径?
编辑 - 解决方案
select x.value('(Parent1/Separator1/Child1)[1]', 'varchar(max)') as Col1,
x.value('(Parent2/Separator2/Child2)[1]', 'varchar(max)') as Col2,
x.value('(Parent3)[1]', 'varchar(max)') as Col3
from [XMLTable] T
cross apply T.XMLCOL.nodes('/Root/Elem1') a(x)
上面的查询只需要大约一秒钟。它似乎是最快的。因此,可以使用ADO.NET功能动态准备和执行上述查询,而不是使用带有参数的表值函数
请纠正我...?