-- Add schema
CREATE XML SCHEMA COLLECTION MySchema AS N'<xs:schema xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
attributeFormDefault="unqualified"
elementFormDefault="qualified"
xmlns="http://mynamespace"
targetNamespace="http://mynamespace">
<xs:element name="element1" type="element1Type">
</xs:element>
<xs:complexType name="element1Type">
<xs:sequence minOccurs="0" maxOccurs="unbounded">
<xs:element name="element2" type="element2Type" />
</xs:sequence>
</xs:complexType>
<xs:complexType name="element2Type">
<xs:sequence>
<xs:element name="element3" type="element3Type" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
<xs:complexType name="element3Type">
<xs:sequence minOccurs="0">
<xs:element minOccurs="0" name="element4" />
</xs:sequence>
</xs:complexType>
</xs:schema>'
GO
-- Create table
CREATE TABLE [dbo].[MyTable](
[XmlColumn] [xml](CONTENT [dbo].[MySchema]) NOT NULL
)
GO
-- Add test data
INSERT INTO MyTable SELECT N'<element1 xmlns="http://mynamespace" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<element2>
<element3>
<element4>my text here</element4>
</element3>
</element2>
</element1>'
GO
-- run query
WITH XMLNAMESPACES(
'http://mynamespace' as s,
DEFAULT 'http://mynamespace'
)
SELECT
T.rows.value('(element3/element4)[1]/text()', 'varchar(100)') as [AtomicValue]
FROM
MyTable
CROSS APPLY
XmlColumn.nodes('/element1/element2') T(rows)
XQuery [MyTable.XmlColumn.value()]: 'text()' is not supported on simple typed or 'http://www.w3.org/2001/XMLSchema#anyType' elements, found 'element({http://mynamespace}:element4,xs:anyType) ?'.
您可以使用query
,然后使用value
。
WITH XMLNAMESPACES(
'http://mynamespace' as s,
DEFAULT 'http://mynamespace'
)
SELECT
T.rows.query('element3/element4').value('.', 'varchar(100)')
FROM
MyTable
CROSS APPLY
XmlColumn.nodes('/element1/element2') T(rows)
也可以在架构中指定element4
的类型。
<xs:element minOccurs="0" name="element4" type="xs:string"/>
并使用此查询
WITH XMLNAMESPACES(
'http://mynamespace' as s,
DEFAULT 'http://mynamespace'
)
SELECT
T.rows.value('(element3/element4)[1]', 'varchar(100)') as [AtomicValue]
FROM
MyTable
CROSS APPLY
XmlColumn.nodes('/element1/element2') T(rows)
如何能够基于另一个同级节点的属性选择节点属性?我想要实现的是从所有节点中提取链接(href值),这些节点后跟具有属性class=“body table news loss”的节点跨度,即选择器应该返回https://finance.yahoo.com/news/inspiremd-announces-planned-recapitalization-120000752.html在下面的示例中。我试
element ui 树状表格选择父节点子节点全选,子节点不全选父节点半选? el-table没有相关示例,需要手动实现好像?![上传中...]()
element ui 树状表格选择父节点子节点全选,子节点不全选父节点半选? el-table没有相关示例,需要手动实现好像?
我正在尝试创建az xpath,我想在其中获取一个节点,其中存在一个具有属性的子节点。我的问题是,这个结构中唯一的区别是子属性。这里有一个例子来告诉你我的意思: 例如,给定UniqueName3,我想获取包含它的记录。到目前为止,我尝试了以下操作: 然而,有了这个,我得到了所有具有field_name属性的值节点。
我有一个XML文档,它包含一个非常复杂(对我来说)的结构,没有换行符。它有许多具有类似结构的元素: 我需要得到节点值的文本,这是节点成员的孩子也有孩子的名字与特定的文本(在这种情况下virtual_size)。也有可能存在几个类似的节点。我可以用[1]etc吗? 这让我知道了节点的名称,但是如何达到“值”节点呢?
问题内容: 我想从NTEXT列中获取一个xml节点值,该列包含基于在另一个xml节点值上查询的where子句的xml。 RDBMS类型:Microsoft SQL Server T-SQL 这里:我想基于StoreId where子句值获取Code节点值。我如何得到它?输入:100输出:ABCDE 例如: 问题答案: 如果您使用的是SQL Server 2005或2008,则可以使用XQuery,