通行证: 用户 密码 域名空间  下载中心 社区论坛 信息公告 MY小屋
联系我们
设为首页
加入收藏

 

QQ,ASP,PHP,JSP,XML,SQL,.Net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | Q Q 专栏 | 建站经验 | 在线工具 | 站长Club | 注 册 表 | 旧版
社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 韩国素材 | 素材图库 | 广告服务 | 服务
当前位置:首页>>编程开发>>SQL专区>>正文 新版上线![旧版]
注:打开慢时请稍等

SQL Server2005的XML数据类型之基础篇

http://www.iyit.net  日期:2006-9-29 22:48:58  来源:  点击:
参加讨论】   一、 引言

  如今,在SQL Server 2005中,XML成为第一流的数据类型。借助于基于XML模式的强类型化支持和基于服务器端的XML数据校验功能,现在,开发者可以对存储的XML文档进行轻松地远程修改。

  作为数据库开发者,许多人都必须大量地涉及XML。

  如今,在SQL Server 2005中,你能以一种新的数据类型的形式把XML存储在数据库中。

  事实上,在SQL Server 2000中就已经包括了一些XML特征。其中,最关键的特征是使用FOR XML语句以XML形式返回结果。SQL Server 2005的功能则明显不同。在SQL Server 2005中,XML是一种真正的数据类型;这意味着,你可以使用XML作为表和视图中的列,XML可以用于T-SQL语句中或作为存储过程的参数。现在,你可以直接在数据库中存储、查询和管理XML文件。

  更重要的是,现在你还能规定你的XML必须遵从的模式。

  在SQL Server 2005中,除了提供机制以校验你的数据库中的XML类型之外,它还允许你描述要被存储的复杂数据类型并且提供一个引擎来强制施加这些规则。

  二、 使用XML数据类型

  其实,XML数据类型与SQL Server中的其它数据类型并不存在根本的区别。你可以把它用在使用任何普通SQL数据类型的地方。例如,下列语句创建一个XML变量并用一个XML填充它:

DECLARE @doc xml
SELECT @doc = '<Team name="Braves" />'

  另外,你还可以使用一个查询和SQL Server的FOR XML语法来填充一个XML变量:

SELECT @doc =
(SELECT * FROM Person.Contact FOR XML AUTO)

  XML数据类型不仅可以作为变量使用,也可以应用于表列中。你还能分配缺省值并且支持NOT NULL约束:

CREATE TABLE Team
(
TeamID int identity not null,
TeamDoc xml DEFAULT '<Team />' NOT NULL
)

  注意:SQL Server 2005的XML功能与SQL Server 2000中具有明显的不同。

  把XML数据插入到表格中只需要用字符串形式的XML指定即可。

  下列示例插入一组记录:

INSERT INTO Team (TeamDoc)
VALUES ('
<Team name="Braves">
<Players>
<Pitcher name="John Smoltz"
role="Closer"/>
</Players>
</Team>');
INSERT INTO Team (TeamDoc)
VALUES ('
<Team name="Red Sox">
<Players>
<Pitcher name="Petro Martinez"
role="Starter"/>
</Players>
</Team>');

  当在SQL Server 2005中创建XML的实例时,唯一的转换是从一个字符串转换成一个XML类型。同样,沿着相反的方向,你只可以把XML类型转换成一个字符串类型。在text和ntext类型之间转换是不允许的。

  三、 XML数据类型的限制

  尽管在SQL Server 2005中XML数据类型就象许多其它数据类型一样对待,但是还存在一些如何使用它的具体限制。这些限制是:

  · XML类型不能转换成text或ntext数据类型。

  · 除了string类型,没有其它数据类型能够转换成XML。

  · XML列不能应用于GROUP BY语句中。

  · 分布式局部(partitioned)视图不能包含XML数据类型。

  · sql_variant实例的使用不能把XML作为一种子类型。

  · XML列不能成为主键或外键的一部分。

  · XML列不能指定为唯一的。

  · COLLATE子句不能被使用在XML列上。

  · XML列不能加入到规则中。

  · 唯一可应用于XML列的内置标量函数是ISNULL和COALESCE。没有任何其它内置标量函数支持使用XML类型。

  · 表中最多只能拥有32个XML列。

  · 具有XML列的表不能有一个超过15列的主键。

  · 具有XML列的表不能有一个timestamp数据类型作为它们的主键的一部分。

  · 存储在数据库中的XML仅支持128级的层次。

本新闻共5页,当前在第1页  1  2  3  4  5  


编辑:黑鹰 [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:SQL SERVER服务器的“偷梁换柱”
下一篇:SQL Artisan 1.3功能使用介绍
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
SQL SERVER服务器的“偷梁换柱” SQL SERVER 2005 同步复制技术 比较SQL Server2005和Oracle 10g R2
SQL Server安装文件挂起错误解决办法 SQL Artisan 1.3功能使用介绍 SQL SERVER服务器的“偷梁换柱”
修改SQL Server 2000身份验证模式和系统 Java编程中更新XML文档的常用方法 JSP+MYSQL+Java类优化分页
Java中四种XML解析技术 Java中关于XML的API JBuilderX+SQL Server开发hibernate
XML到Java代码的数据绑定之对象 Visual C#的SQL Server编程 Visual C#的SQL Server编程
用perl访问mysql数据库之一 用perl访问mysql数据库之二 ASP.NET中的XML表单控件
.Net的精髓-XML和SOAP(一) .Net的精髓-XML和SOAP(二) .Net的精髓-XML和SOAP(三)
ASP.NET连SQL7接口源代码 .Net中将图片数据保存到XML文档  一个用Wsh来控制SqlServer的Dcom的VBs
最新更新 热点排行 推荐新闻
通用分页存储过程,源码共享,大家共同
SQL SERVER服务器的“偷梁换柱”
SQL SERVER 2005 同步复制技术
比较SQL Server2005和Oracle 10g R2
SQL Server安装文件挂起错误解决办法
4DOS的用法
双机互联的工具LapLink的使用
DOS环境变量“全家福”
DOS命令淘金——ECHO命令的使用
终极DOS任务
MSDOS.SYS文件的设置
我的系统恢复盘
DOS使用中的常见问题解答
CMOS密码破解全攻略
DOS复兴运动
通用分页存储过程,源码共享,大家共同
SQL SERVER服务器的“偷梁换柱”
SQL SERVER 2005 同步复制技术
比较SQL Server2005和Oracle 10g R2
SQL Server安装文件挂起错误解决办法
QQ密码被盗怎么办!我教你找回密码
轻易破解Winrar,Winzip密码
备份软件GHOST使用教程
Ghost批处理命令用法详解
如何控制我的电脑只允许登录我自己的Q
QQ2006 Beta3隆重发布 实用功能一一奉
美国微软总部相中重庆15岁网络奇才(图
百度声明称遭受有史以来最大规模黑客攻
被删除系统文件恢复全攻略
使用身份验证来禁止内部用户上网 
SQL简明教程(1)
快速安装Windows操作系统独家秘籍
30秒清除Windows系统所有垃圾
系统盘符错乱的解决方案
由Windows远程桌面想到的复制粘贴问题
不输密码照样登陆操作系统
Windows下的虚拟主机设置全功略
Windows操作系统完美维护技巧
Ghost备份问题精彩解决方法集锦
菜鸟学电脑之端口基础知识
QQ号码激活的常见问题及案例分析 
 友情链接
设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyrights © 2004-2006 iYiT.Net All Rights Reserved.
网站合作、广告联系QQ:147007642、466949678
易特网络技术 点击这里给我发消息