【发布时间】:2016-08-18 17:31:22
【问题描述】:
我有以下脚本的 SQL 视图。由于表将数据存储为 XML (dbo.TEST.configuration),因此我必须通过读取 xml 数据来选择每一列。但是当记录增加时,加载速度太慢了。有什么方法可以提高它的性能,请告诉我?
WITH XMLNAMESPACES( DEFAULT 'http://tempuri.org/xmlConfiguration.xsd')
SELECT dbo.TEST.uid, dbo.TEST.name, dbo.TEST.ClassUid, dbo.TEST.xmlData,
CAST(REPLACE(CAST(dbo.TEST.configuration AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/batchUid)[1]', 'NVARCHAR(200)') AS batchUid,
CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/statusUid)[1]', 'NVARCHAR(200)') AS statusUid,
CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/subjectUid)[1]', 'NVARCHAR(200)') AS subjectUid,
CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/cultureUid)[1]', 'NVARCHAR(200)') AS cultureUid,
CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/format)[1]', 'NVARCHAR(200)') AS format,
CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/secondFormat)[1]', 'NVARCHAR(200)') AS secondFormat,
CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/standardUid)[1]', 'NVARCHAR(200)') AS standardUid
FROM dbo.TEST INNER JOIN
dbo.batch ON CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/batchUid)[1]', 'NVARCHAR(200)') = dbo.batch.uid INNER JOIN
dbo.status ON CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/statusUid)[1]', 'NVARCHAR(200)') = dbo.status.uid INNER JOIN
dbo.vFormat ON CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/format)[1]', 'NVARCHAR(200)') = CONVERT(NVARCHAR(200), dbo.vFormat.uid) OR
CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/secondFormat)[1]', 'NVARCHAR(200)') = CONVERT(NVARCHAR(200), dbo.vFormat.uid) INNER JOIN
dbo.standard ON CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/standardUid)[1]', 'NVARCHAR(200)') = dbo.standard.uid INNER JOIN
mainDb.dbo.Class ON dbo.TEST.ClassUid = mainDb.dbo.Class.uid INNER JOIN
dbo.subject ON CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/subjectUid)[1]', 'NVARCHAR(200)') = dbo.subject.uid INNER JOIN
mainDb.dbo.culture ON CAST(REPLACE(CAST(dbo.TEST.xmlData AS VARCHAR(MAX)), 'encoding="utf-8"', '')
AS XML ).value('(/xmlConfiguration/cultureUid)[1]', 'NVARCHAR(200)') = mainDb.dbo.culture.uid
提前致谢。
示例 xml 数据如下;
<?xml version="1.0" encoding="utf-8"?>
<xmlConfiguration xmlns="http://tempuri.org/xmlConfiguration.xsd">
<secondFormat>3bd3d9cc-ad0a-e611-b086-00e04c6804ad</secondFormat>
<batchUid>c7b4743b-4493-df11-981e-00221933d118</batchUid>
<statusUid>f0b159ec-4193-df11-981e-00221933d118</statusUid>
<subjectUid>d07b5d66-3b5b-de11-b569-001143e78e41</subjectUid>
<cultureUid>c6644752-93d7-df11-981e-00221933d118</cultureUid>
<name>test</name>
<standardUid>dc19869b-3ea9-df11-981e-00221933d118</standardUid>
<format></format>
</ConnectorConfiguration>
【问题讨论】:
-
您有任何统计数据可以显示性能问题吗?
-
这很奇怪... XML 是否存储在数据类型 XML 的列中?这种一次又一次的铸造和替换有任何价值吗?请提供有关您的表结构的更多信息,也许还有一些示例行...
-
我会在派生表中进行所有转换。简化代码。
-
@jarlh 如果数据已经是 XML,则根本不需要强制转换...
-
您的“Uid”值是什么数据类型?这是
UNIQUEIDENTIFIER?您的联接是否总是从一个UNIQUEIDENTIFIER加入到另一类型为UNIQUEIDENTIFIER的列?
标签: sql sql-server performance sql-server-2008 sql-tuning