SQL Server2008 XML增删改查

2024-03-08 04:48

本文主要是介绍SQL Server2008 XML增删改查,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

create xml schema collection dbo.class_xsd as
'<?xml version="1.0" encoding="UTF-8" ?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="class">
<xs:complexType>
<xs:attribute name ="name" type="xs:string" use="required"/>
</xs:complexType>
</xs:element >
<xs:element name="classes">
<xs:complexType>
<xs:sequence>
<xs:element ref="class" maxOccurs="unbounded"/>
</xs:sequence>
</xs:complexType>
</xs:element >
</xs:schema>
'
create table tblspeakers
(
speaker_id int primary key identity,
speaker_nm nvarchar(50),
speaker_country nvarchar(25),
speaker_xml xml (class_xsd) not null
)
--xml index:primary key
create primary xml index idx_1 on tblspeakers(speaker_xml)
--xml index :path
create xml index idx_a on tblspeakers(speaker_xml) using xml index idx_1 for path
--如果没有xsd架构的话 xquery引擎会假定所有内容为非类型作为字符串处理。
--插入数据
insert into tblspeakers values('Stephen Forte','USA','
<classes>
<class name="Writing Secure Code for ASP .NET"/>
<class name="Using XQuery to Query and Manipulate XML Data in SQL Server 2008"/>
<class name="SQL Server and Oracle Working Together"/>
<class name="Protecting against SQL Injection  Attacks"/>
</classes>
')
insert into tblspeakers values('Richard Campbell','Canada','
<classes>
<class name="SQL Server Profiler"/>
<class name="Advanced SQL Querying Techniques"/>
<class name="SQL Server and Oracle Working Together"/>
<class name="T-SQL Error Handling in Yukon"/>
</classes>
')
insert into tblspeakers values('John Huckaby  ','USA','
<classes>
<class name="Smart Client Stuff"/>
<class name="More Smart Client Stuff"/>
</classes>
')
insert into tblspeakers values('Malek Kemmou  ','Morocco','
<classes>
<class name="SmartPhone 2005"/>
<class name="Office System 2003"/>
</classes>
')
insert into tblspeakers values('Goksin Bakir  ','Turkey','
<classes>
<class name="SmartPhone 2007"/>
<class name="Office System 2007"/>
</classes>
')
insert into tblspeakers values('Jan Vasters  ','Germany','
<classes>
<class name="SOA"/>
<class name="Biz Talk Services"/>
</classes>
')
insert into tblspeakers values('Monica L.Tripp','USA','
<classes>
<class name="SQL Server Index  "/>
<class name="SQL Precon  "/>
</classes>
')
insert into tblspeakers values('Bad Speaker','France','
<classes>
<class name="SQL Server Index  "/>
<class name="SQL Precon  "/>
</classes>
')
select * from tblspeakers
--xml.exist 返回1或者0 null ,返回xml数据的元素和属性 
declare @xml as xml 
set @xml='
<classes>
<class name="SQL Server Index  "/>
<class name="SQL Precon  "/>
</classes>
'
select @xml.exist('/classes')
---创建check constraint中使用的函数
create function dbo.DesOrderXMLDataExist(@xml xml)
returns bit
as 
begin
return @xml.exist('/Orders')
end
go
--使用这个函数检查这个xml列必须有节点/Orders
create table OrdersXMLCheck
(
OrderDocID int primary key,
xOrders XML not null default '<Orders/>'
constraint xml_orderconstraint check(dbo.DesOrderXMLDataExist(xOrders)=1)
)
--查询
select * from tblspeakers where speaker_xml.exist('/classes/class[@name="SQL Precon  "]')=1
/*
speaker_id  speaker_nm                                         speaker_country           speaker_xml
----------- -------------------------------------------------- ------------------------- -------------------------------------------------------------------------------------
7           Monica L.Tripp                                     USA                       <classes><class name="SQL Server Index  " /><class name="SQL Precon  " /></classes>
8           Bad Speaker                                        France                    <classes><class name="SQL Server Index  " /><class name="SQL Precon  " /></classes>
(2 行受影响)
*/
--XML.VALUE  查询xml中的节点。。
select speaker_id,speaker_nm,speaker_country,
speaker_xml.value('/classes[1]/class[1]/@name','varchar(50)')'classname' 
from tblspeakers
/*
speaker_id  speaker_nm                                         speaker_country           classname
----------- -------------------------------------------------- ------------------------- ----------------------------------
1           Stephen Forte                                      USA                       Writing Secure Code for ASP .NET
2           Richard Campbell                                   Canada                    SQL Server Profiler
3           John Huckaby                                       USA                       Smart Client Stuff
4           Malek Kemmou                                       Morocco                   SmartPhone 2005
5           Goksin Bakir                                       Turkey                    SmartPhone 2007
6           Jan Vasters                                        Germany                   SOA
7           Monica L.Tripp                                     USA                       SQL Server Index  
8           Bad Speaker                                        France                    SQL Server Index  
(8 行受影响)
*/
--xml.query 
--工作方式和xml.value类是,区别在于它返回一个xml数据类型的值,所以可以具有更大的灵活性。
select speaker_id,speaker_nm,speaker_country,
speaker_xml.query('/classes[1]/class[1]' )'classname' 
from tblspeakers
/*
speaker_id  speaker_nm                                         speaker_country           classname
----------- -------------------------------------------------- ------------------------- -------------------------------------------------- 
1           Stephen Forte                                      USA                       <class name="Writing Secure Code for ASP .NET" />
2           Richard Campbell                                   Canada                    <class name="SQL Server Profiler" />
3           John Huckaby                                       USA                       <class name="Smart Client Stuff" />
4           Malek Kemmou                                       Morocco                   <class name="SmartPhone 2005" />
5           Goksin Bakir                                       Turkey                    <class name="SmartPhone 2007" />
6           Jan Vasters                                        Germany                   <class name="SOA" />
7           Monica L.Tripp                                     USA                       <class name="SQL Server Index  " />
8           Bad Speaker                                        France                    <class name="SQL Server Index  " />
(8 行受影响)
*/
--同时在查询中 xml.query可以去掉参数全部返回 
select speaker_id,speaker_nm,speaker_country,
speaker_xml.query('/classes /class ')as 'classname' 
from tblspeakers
where speaker_country='Canada'
/*
等价于下面的这个for。。。
for $b in /classes/class return($b) xquery扩展
查询
*/
select speaker_id,speaker_nm,speaker_country,
speaker_xml.query('for $b in /classes /class  return ($b)')as 'classname' 
from tblspeakers
where speaker_xml.exist('/classes/class[@name="SQL Server Profiler"]')=1
---xml.query扩展
select speaker_id,speaker_nm,speaker_country,
speaker_xml.query('
for $b in /classes/class  
where $b/@name="Advanced SQL Querying Techniques"
return (<Sessions>{$b}<Speaker id="{sql:column("Speaker_ID")}">
{sql:column("Speaker_NM")}</Speaker></Sessions>)')as 'classname' 
from tblspeakers
where speaker_xml.exist('/classes/class[@name="SQL Server Profiler"]')=1
/*
speaker_id  speaker_nm                                         speaker_country           classname
----------- -------------------------------------------------- ------------------------- ------------------------------------------------------------------------------------------------------------------- 
2           Richard Campbell                                   Canada                    <Sessions><class name="Advanced SQL Querying Techniques" /><Speaker id="2">Richard Campbell</Speaker></Sessions>
(1 行受影响)
*/
--XML DML
--xml.modify(insert)
update tblspeakers set speaker_xml.modify('
insert <class name="pppp"/> 
into /classes[1]') where speaker_id=8
declare @newxml xml
set @newxml='<class name="Ranking and Windowing Functions in SQL Server 2008"/>'
update tblspeakers  set speaker_xml.modify('insert sql:variable("@newxml") into /classes[1]' )
--xml.modify(delete)
update tblspeakers set speaker_xml.modify(
'delete /classes[1]/class[2] '
)
where speaker_id=8
select * from tblspeakers
--xml.modify(replace)
update tblspeakers set speaker_xml.modify('
replace value of classes[1]/class[1]/@name[1]
with " fuck you !!"
') where speaker_id=8

这篇关于SQL Server2008 XML增删改查的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/786053

相关文章

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

MySQL 衍生表(Derived Tables)的使用

《MySQL衍生表(DerivedTables)的使用》本文主要介绍了MySQL衍生表(DerivedTables)的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录一、衍生表简介1.1 衍生表基本用法1.2 自定义列名1.3 衍生表的局限在SQL的查询语句select

MySQL 横向衍生表(Lateral Derived Tables)的实现

《MySQL横向衍生表(LateralDerivedTables)的实现》横向衍生表适用于在需要通过子查询获取中间结果集的场景,相对于普通衍生表,横向衍生表可以引用在其之前出现过的表名,本文就来... 目录一、横向衍生表用法示例1.1 用法示例1.2 使用建议前面我们介绍过mysql中的衍生表(From子句

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二: