Hãy thử điều này:
;WITH XMLNAMESPACES ('http://3ecompany.com/webservices/catalogitemxml' as CI)
SELECT
Identifier = CI.value('(CI:ProductIdentifiers[1]/CI:Identifier)[1]', 'varchar(9)'),
CAS_Number = Ingred.value('(CI:Cas)[1]', 'varchar(20)'),
Chemical_Name = Ingred.value('(CI:ChemicalName)[1]', 'varchar(100)')
FROM
@XmlTable
CROSS APPLY
XMLData.nodes('/ArrayOfCatalogItem/CatalogItem/CI:Msds') AS XT(CI)
CROSS APPLY
CI.nodes('CI:Ingredients') AS XT18(Ingred)
Tôi nhận được danh sách các đoạn XML cho mỗi <Msds>
và từ nút này, tôi lấy ProductIdentifiers
thông tin. Ngoài ra, từ nút này, tôi cũng nhận được danh sách các phân đoạn XML phụ cho <Ingredients>
và nắm bắt thông tin chi tiết từ những nút này.
Đầu ra của tôi trông như thế này: