关于 XML 字段内容查询
找到个总结相当好的知识点的归纳,记在自己的博客里也方便查询
/*
sql xml 入门:
--by jinjazz
--http://blog.csdn.net/jinjazz
1、xml: 能认识元素、属性和值
2、xpath: 寻址语言,类似windows目录的查找(没用过dir命令的话就去面壁)
语法格式,这些语法可以组合为条件:
"."
表示自己,
".."
表示父亲,
"/"
表示儿子,
"//"
表示后代,
"name"
表示按名字查找,
"@name"
表示按属性查找
"集合[条件]"
表示根据条件取集合的子集,条件可以是
数 值:数字,
last
(),
last
()-数字 等
布尔值:position()<数字,@
name
=
'条件'
,
name
=
'条件'
条件是布尔值的时候可以合并计算:
and
or
3、xquery: 基于xpath标的准查询语言,sqlserver xquery包含如下函数
exist(xpath条件):返回布尔值表示节点是否存在
query(xpath条件):返回由符合条件的节点组成的新的xml文档
value(xpath条件,数据类型):返回指定的标量值,xpath条件结果必须唯一
nodes(xpath条件): 返回由符合条件的节点组成的一行一列的结果表
*/
declare
@data xml
set
@data=
'
<bookstore>
<book category="COOKING">
<title lang="en">Everyday Italian</title>
<author>Giada De Laurentiis</author>
<year>2005</year>
<price>30.00</price>
</book>
<book category="CHILDREN">
<title lang="jp">Harry Potter</title>
<author>J K. Rowling</author>
<year>2005</year>
<price>29.99</price>
</book>
<book category="WEB">
<title lang="en">XQuery Kick Start</title>
<author>James McGovern</author>
<author>Per Bothner</author>
<author>Kurt Cagle</author>
<author>James Linn</author>
<author>Vaidyanathan Nagarajan</author>
<year>2003</year>
<price>49.99</price>
</book>
<book category="WEB">
<title lang="cn">Learning XML</title>
<author>Erik T. Ray</author>
<year>2003</year>
<price>39.95</price>
</book>
</bookstore>
'
--测试语句,如果不理解语法请参考上面的xpath规则和xquery函数说明
--1、文档
select
@data
--2、任意级别是否存在price节点
select
@data.exist(
'//price'
)
--3、获取所有book节点
select
@data.query(
'//book'
)
--4、获取所有包含lang属性的节点
select
@data.query(
'//*[@lang]'
)
--5、获取第一个book节点
select
@data.query(
'//book[1]'
)
--6、获取前两个book节点
select
@data.query(
'//book[position()<=2]'
)
--7、获取最后一个book节点
select
@data.query(
'//book[last()]'
)
--8、获取price>35的所有book节点
select
@data.query(
'//book[price>35]'
)
--9、获取category="WEB"的所有book节点
select
@data.query(
'//book[@category="WEB"]'
)
--10、获取title的lang="en"的所有book节点
select
@data.query(
'//book/title[@lang="en"]'
)
--11、获取title的lang="en"且 price>35的所有book节点
select
@data.query(
'//book[./title[@lang="en"] or price>35 ]'
)
--12、获取title的lang="en"且 price>35的第一book的(第一个)title
select
@data.query(
'//book[./title[@lang="en"] and price>35 ]'
).value(
'(book/title)[1]'
,
'varchar(max)'
)
--13、等价于12
select
@data.value(
'(//book[./title[@lang="en"] and price>35 ]/title)[1]'
,
'varchar(max)'
)
--14、获取title的lang="en"且 price>35的第一book的(第一个)title的lang属性
select
@data.value(
'((//book[@category="WEB" and price>35 ]/title)[1]/@lang)[1]'
,
'varchar(max)'
)
--15、获取第一本书的title
select
Tab.Col.value(
'(book/title)[1]'
,
'varchar(max)'
)
as
title
from
@data.nodes(
'bookstore'
)
as
Tab(Col)
--16、获取每本书的第一个author
select
Tab.Col.value(
'author[1]'
,
'varchar(max)'
)
as
title
from
@data.nodes(
'//book'
)
as
Tab(Col)
--17、获取所有book的所有信息
select
T.C.value(
'title[1]'
,
'varchar(max)'
)
as
title,
T.C.value(
'year[1]'
,
'int'
)
as
year
,
T.C.value(
'title[1]'
,
'varchar(max)'
)
as
title,
T.C.value(
'price[1]'
,
'float'
)
as
price,
T.C.value(
'author[1]'
,
'varchar(max)'
)
as
author1,
T.C.value(
'author[2]'
,
'varchar(max)'
)
as
author2,
T.C.value(
'author[3]'
,
'varchar(max)'
)
as
author3,
T.C.value(
'author[4]'
,
'varchar(max)'
)
as
author4
from
@data.nodes(
'//book'
)
as
T(C)
--18、获取不是日语(lang!="jp")且价格大于35的书的所有信息
select
T.C.value(
'title[1]'
,
'varchar(max)'
)
as
title,
T.C.value(
'year[1]'
,
'int'
)
as
year
,
T.C.value(
'title[1]'
,
'varchar(max)'
)
as
title,
T.C.value(
'price[1]'
,
'float'
)
as
price,
T.C.value(
'author[1]'
,
'varchar(max)'
)
as
author1,
T.C.value(
'author[2]'
,
'varchar(max)'
)
as
author2,
T.C.value(
'author[3]'
,
'varchar(max)'
)
as
author3,
T.C.value(
'author[4]'
,
'varchar(max)'
)
as
author4
from
@data.nodes(
'//book[./title[@lang!="jp"] and price>35 ]'
)
as
T(C)
XML 字段在做数据库设计的时可以发挥巨大的作用 举个例子,就是为同一类但又互相有区别的数据对象,比如之前做的海关项目的不同种类的文书,这次做的引擎扫描对象的记录等等建立共同使用的通用数据表使用 XML字段可以存放不同数据结构,可以把互相不同的数据对象中不同的部分,存放至XML字段中,相同的部分抽象出来存放于正常字段中,这样的设计 既可以简化数据库的表,又能满足不同数据对象的查询需求,感觉以后可以多试试使用这种方法。
关于 XML 字段内容查询的更多相关文章
- 记一次SQL xml字段关联查询
需求: 一张表是APP表,结构如下: app_category为该游戏所属的类别ID,xml字段类型 另一张表是类别表,就ID对应名称,这就不上图了. 还有一张表是每个游戏的下载记录,结构如下: Do ...
- SQL Server对Xml字段的操作
T-Sql操作Xml数据 一.前言 SQL Server 2005 引入了一种称为 XML 的本机数据类型.用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列:此外,还允许带有变量和 ...
- (转)SQL对Xml字段的操作
T-Sql操作Xml数据 一.前言 SQL Server 2005 引入了一种称为 XML 的本机数据类型.用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列:此外,还允许带有变量和 ...
- SQL对Xml字段的操作
转:http://www.cnblogs.com/youring2/archive/2008/11/27/1342288.html T-Sql操作Xml数据 一.前言 SQL Server 2005 ...
- DB2数据库操作XMl字段
1.xml查询语句 ① 查询xml中的单个节点内容 select TM_PRM_OBJECT.ORG , TM_PRM_OBJECT.PARAM_CLASS , TM_PRM_OBJECT.PARAM ...
- (轉載)sql server xml字段的操作
原文轉自:http://blog.csdn.net/hliq5399/article/details/8315373 另外可參考:https://msdn.microsoft.com/en-us/li ...
- SQL Server 2008中如何为XML字段建立索引
from:http://blog.csdn.net/tjvictor/article/details/4370771 SQL Server中的XML索引分为两类:主XML 索引和辅助XML索引.其中辅 ...
- mybatis mapper.xml 写关联查询 运用 resultmap 结果集中 用 association 关联其他表 并且 用 association 的 select 查询值 报错 java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for mybatis.map
用mybaits 写一个关联查询 查询商品表关联商品规格表,并查询规格表中的数量.价格等,为了sql重用性,利用 association 节点 查询 结果并赋值报错 商品表的mapper文件为Gooo ...
- Oracle中使用游标转换数据表中指定字段内容格式(拼音转数字)
应用场景:将数据表TB_USER中字段NNDP的内容中为[sannanyinv]转换为[3男1女] 主要脚本:一个游标脚本+分割字符串函数+拼音转数字脚本 操作步骤如下: 1.创建类型 create ...
随机推荐
- layui导航的使用
在项目开发的时候,需要后台的系统好看点,左边的导航需要设计为多级的,而且要点击当前的链接页面,刷新后要实现选中状态 学习源头:http://www.layui.com/doc/element/nav. ...
- HTTP-头域
头域 每个头域由一个域名,冒号(:)和域值三部分组成.域名是大小写无关的,域值前可以添加任何数量的空格符,头域可以被扩展为多行,在每行开始处,使用至少一个空格或制表符. HTTP请求消息 HTTP状态 ...
- 【转】学习使用Jmeter做压力测试(三)--数据库测试
JMeter可以做为Web服务器与浏览器之间的代理网关,以捕获浏览器的请求和Web服务器的响应,这样就可很容易的生成性能测试脚本.根据脚本,JMeter可通过线程组来模拟真实用户对Web服务器做压力测 ...
- PTA 词频统计(30 分)
词频统计(30 分) 请编写程序,对一段英文文本,统计其中所有不同单词的个数,以及词频最大的前10%的单词. 所谓“单词”,是指由不超过80个单词字符组成的连续字符串,但长度超过15的单词将只截取保留 ...
- 工具软件集合 Adobe AE PS Pr CC 2018 2019 破解教程
来源https://mp.weixin.qq.com/s/zeq1sTmaPsKt7Bsok0Ldrg(若链接失效,请关注软件安装管家公众号) 相关链接 Office 2019破解教程 Adobe 2 ...
- Unity Shader入门精要读书笔记(三)Shader必须的数学基础
Xyz三维坐标系如下:左手坐标系 但是摄像机观察空间则是采用右手系: 右手法则判断叉乘的结果的方向: 正交矩阵(单位互相垂直的基矢量构成正交矩阵)具有逆与转置一致性: 列矩阵运算CBAv和行矩阵的运算 ...
- 转:Oracle里几组重要的视图--v$sysstat,v$system_event,v$parameter v$system_parameter
按组分的几组重要的性能视图 1.System 的 over view v$sysstat , v$system_event , v$parameter,V$instance得到oracle_sid ...
- keepalived 预防脑裂检测脚本
1 检查vip [root@mysql2 keepalived]# cat /etc/keepalived/check_brain_keepalived.sh #!/bin/bash # 检查脑裂的脚 ...
- Fragment的陷阱:概述
现在主流的APP都会使用到Fragment,相信你也一定使用过,今天为大家介绍一下我曾经踏过的一个关于Fragment的坑. 以前做过的一个项目,Fragment嵌套高德地图,当再次进入Fragmen ...
- SVN安装和使用总结
SVN简介: 为什么要使用SVN? 程序员在编写程序的过程中,每个程序员都会生成很多不同的版本,这就需要程序员有效的管理代码,在需要的时候可以迅速,准确取出相应的版本. Subversion是什么? ...