Пытаетесь понять, почему нельзя использовать sql_variant для типа значения при использовании функции узлов XML в SQL Server? У меня есть сценарий, в котором я буду динамически анализировать некоторые входные данные XML, и возможность использования sql_variant будет хорошей альтернативой необходимости присваивать переменную типа данных или выполнять поиск по sys.columns.
Пример:
IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[XmlSourceTable]') AND type in (N'U'))
DROP TABLE [dbo].[XmlSourceTable]
GO
CREATE TABLE [dbo].[XmlSourceTable](
[RecordId] [int] IDENTITY(1,1) NOT NULL,
[XmlData] [xml] NOT NULL,
PRIMARY KEY CLUSTERED
(
[RecordId] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
DECLARE @XML XML ='<?xml version="1.0" ?>
<Root>
<Person>
<Name>Simon</Name>
<Age>20</Age>
<Skills>
<Skill>Cooking</Skill>
<Skill>Cleaning</Skill>
</Skills>
</Person>
<Person>
<Name>Peter</Name>
<Age>21</Age>
<Skills>
<Skill>Ironing</Skill>
</Skills>
</Person>
</Root>'
INSERT INTO XmlSourceTable(XmlData)
SELECT @XML
GO
SELECT * FROM XmlSourceTable
GO
SELECT
pref.value('(Name/text())[1]', 'varchar(50)') as PersonName,
pref.value('(Age/text())[1]', 'int') as PersonAge,
pref.query('Skills') as PersonSkills
FROM
XmlSourceTable CROSS APPLY
XmlData.nodes('/Root/Person') AS People(pref)
Так вместо:
SELECT * FROM XmlSourceTable
GO
SELECT
pref.value('(Name/text())[1]', 'varchar(50)') as PersonName,
pref.value('(Age/text())[1]', 'int') as PersonAge,
pref.query('Skills') as PersonSkills
FROM
XmlSourceTable CROSS APPLY
XmlData.nodes('/Root/Person') AS People(pref)
Было бы неплохо использовать:
SELECT * FROM XmlSourceTable
GO
SELECT
pref.value('(Name/text())[1]', 'sql_variant') as PersonName,
pref.value('(Age/text())[1]', 'sql_variantt') as PersonAge,
pref.query('Skills') as PersonSkills
FROM
XmlSourceTable CROSS APPLY
XmlData.nodes('/Root/Person') AS People(pref)
Но я получаю эту ошибку:
Сообщение 9500, уровень 16, состояние 1, строка 1
Тип данных sql_variant), используемый в методе VALUE, недопустим.
В любом случае использовать sql_variant в функции узлов?
Спасибо
S