I'm trying to read an XML file, the aim is to get ddscontrol to return
888
in one record and
999
in the other.
Similarly for tooltip I need to return
TTT111
and
TTT222
I can't seem to go deeper beyond dds though for some reason, here's a simplified script to run in SSMS:
DECLARE @XML AS XML = '
<Create xmlns="http://schemas.microsoft.com/analysisservices/2003/engine">
<ObjectDefinition>
<Database>
<ID>White Stuff BI OLAP Solution</ID>
<Dimensions>
<Dimension>
<ID>Dim Dynamic Date Filter</ID>
<Annotations>
<Annotation>
<Name>http://schemas.microsoft.com/DataWarehouse/Designer/1.0:DiagramLayout</Name>
<Value>
<dds xmlns="this is an XML namespace">123
<ddscontrol tooltip="TTT111">888</ddscontrol></dds>
abc</Value>
</Annotation>
<Annotation>
<Name>http://schemas.microsoft.com/DataWarehouse/Designer/1.0:DiagramLayout</Name>
<Value>
<dds xmlns="this is an XML namespace">456
<ddscontrol tooltip="TTT222">999</ddscontrol></dds>
abc</Value>
</Annotation>
</Annotations>
</Dimension>
</Dimensions>
</Database>
</ObjectDefinition>
</Create>'
;WITH XMLNAMESPACES
(
DEFAULT 'http://schemas.microsoft.com/analysisservices/2003/engine',
'this is an XML namespace' AS ns2
)
SELECT
a.value('(../../../../ID/text())[1]', 'nvarchar(100)') as [First ID]
,a.value('(../../ID/text())[1]', 'nvarchar(100)') as [Second ID]
,a.value('(Name/text())[1]', 'nvarchar(1000)') as [Name]
,a.value('(Value/text())[1]', 'nvarchar(1000)') as [Value]
,a.value('(Value/ns2:dds/text())[1]', 'nvarchar(1000)') as [dds]
,a.value('(Value/ns2:dds/ddscontrol/text())[1]', 'nvarchar(1000)') as [ddscontrol]
,a.value('(Value/ns2:dds/ddscontrol/@tooltip)[1]', 'nvarchar(1000)') as [tooltip]
FROM @XML.nodes('/Create/ObjectDefinition/Database/Dimensions/Dimension/Annotations/Annotation') as x1(a)

As @Larnu already mentioned, the XML doesn't look right.
Please try the following solution.
Notable points:
../text()is added to XPath expressions for performance reasons.SQL