Я пытаюсь создать функцию SQL, которая возвращает значение через месяц, разделенное запятыми, со значением true, прочитав xmlNode.
Однако я вообще не могу перейти к узлу месяцев.
Добавление пространства имен к пути не помогло мне извлечь значение из Node.Data
Для первого узла (StartDateTime) я смог извлечь значение в похожих строках (используя путь как
/ ScheduleDefinition / StartDateTime
Пожалуйста, используйте код ниже:
CREATE FUNCTION [dbo].[GetMonthsFromXML]
(
-- Add the parameters for the function here
@xmlText NTEXT
)
RETURNS VARCHAR(MAX)
AS
BEGIN
/*
<ScheduleDefinition>
<StartDateTime>04/10/2019 06:00:00</StartDateTime>
<MonthlyRecurrence xmlns="http://schemas.microsoft.com/sqlserver/reporting/2010/03/01/ReportServer">
<Days>29</Days>
<MonthsOfYear>
<January>true</January>
<February>false</February>
<March>true</March>
<April>true</April>
<May>false</May>
<June>false</June>
<July>false</July>
<August>false</August>
<September>false</September>
<October>false</October>
<November>false</November>
<December>false</December>
</MonthsOfYear>
</MonthlyRecurrence>
</ScheduleDefinition>
*/
DECLARE @resultVar VARCHAR(MAX)
DECLARE @x xml
SET @x = CAST(@xmlText AS XML);
;with cte
as
(
SELECT
[MonthName] = Node.Data.value('local-name(.)', 'VARCHAR(20)')
,MonthValue = Node.Data.value('(.)[1]', 'VARCHAR(20)')
FROM
@x.nodes('/ScheduleDefinition/MonthlyRecurrence/MonthsOfYear') Node(Data)
)
select @resultVar = ISNULL( MAX(MonthValue),'') from cte; --where MonthValue is not null and MonthValue <> '' ;
-- Return the result of the function
RETURN @resultVar
END
GO
Январь, март, апрель - ожидаемый результат для вышеуказанного xml