SQL Server 2008 中的hierarchyid类型应用

  SQL Server 2008的一个重要新增特性。主要解决的问题是拥有层次关系的表格。例如我们日常生活中用到最多的组织结构图。我们一般会用一个Employees表保存员工数据,而每个员工则又可能会有相应的上级。以前要得到某个员工的所有上级,或者所有下级,通常所采取的方法都是递归。SQL Server 2005开始支持的CTE从一定程序上方便了该工作的实现。

  但SQL 2008的hierarchyid让这个工作更加简化和直接。而该类型其实是一个CLR自定义数据类型。


  一般我们使用的时候,如下面的例子

  --创建表

  CREATE TABLE Employees

  (

  Org_Id hierarchyid NOT NULL,

  EmployeeId INT NOT NULL,

  EmployeeName VARCHAR(50) NOT NULL,

  Title VARCHAR(50) NOT NULL

  )

  GO

  --插入一些员工,注意第一个列的格式,必须用/开始和结束。这是一个路径的符号。这是一个关键

  INSERT INTO dbo.Employees VALUES('/',10000,'陈希章','CEO');

  INSERT INTO dbo.Employees VALUES('/1/',10001,'张三','CTO');

  INSERT INTO dbo.Employees VALUES('/2/',10002,'李四','CFO');

  INSERT INTO dbo.Employees VALUES('/1/1/',10003,'王五','IT Manager');

  INSERT INTO dbo.Employees VALUES('/1/2/',10004,'赵六','Manager');

  INSERT INTO dbo.Employees VALUES('/1/1/1/',10005,'洪七','Employee');

  --查看所有的员工

  SELECT * FROM dbo.Employees


  --查看所有的员工及其级别

  SELECT *,Org_Id.GetLevel() AS Level FROM Employees


  --查看陈希章的所有下属

  DECLARE @BOSS hierarchyid

  SELECT @BOSS=Org_Id FROM Employees WHERE EmployeeID=10000

  SELECT *,Org_Id.GetLevel()AS Level FROM Employees WHERE Org_Id.IsDescendantOf(@BOSS)=1


  --查看赵六及其所有上级

  DECLARE @Employee hierarchyid

  SELECT @Employee=Org_Id FROM Employees WHERE EmployeeID=10004

  SELECT *,Org_Id.GetLevel()AS Level FROM Employees WHERE @Employee.IsDescendantOf(Org_Id)=1


  与hierarchyid有关的一些函数主要有

  GetAncestor :取得某一个级别的祖先

  GetDescendant :取得某一个级别的子代

  GetLevel :取得级别

  GetRoot :取得根

  IsDescendantOf :判断某个节点是否为某个节点的子代

  Parse :将字符串转换为hierarchyid。该字符串的格式通常都是/1/这样的

  Read :

  Read 从传入的 BinaryReader 读取 SqlHierarchyId 的二进制表示形式,并将 SqlHierarchyId 对象设置为该值。不能使用 Transact-SQL 调用 Read。请改为使用 CAST 或 CONVERT。

  GetReparentedValue :可以用来移动节点(或者子树)

  ToString :将hierarchyid转换为字符串,与parse正好相反

  Write

  Write 将 SqlHierarchyId 的二进制表示形式写出到传入的 BinaryWriter 中。无法通过使用 Transact-SQL 来调用 Write。请改为使用 CAST 或 CONVERT。

时间: 2024-10-31 05:38:44

SQL Server 2008 中的hierarchyid类型应用的相关文章

SQL Server 2008中的hierarchyid

本人转载:http://www.cnblogs.com/chenxizhang/archive/2009/04/26/1444016.html 一般我们使用的时候,如下面的例子 --创建表 CREATE TABLE Employees ( Org_Id hierarchyid NOT NULL, EmployeeId INT NOT NULL, EmployeeName VARCHAR(50) NOT NULL, Title VARCHAR(50) NOT NULL ) GO --插入一些员工,

在SQL Server 2008中使用空间数据实现位置智能

1. 导言 现今的信息工作人员和消费者处理大量不同类型的信息,从电子表格和数据库中的商业数据的传统数 据表,到在线的基于媒体的数据例如视频.照片和音乐.近来朝向mash up解决方案(mash up解决方案是 指合并从多个来源获得的信息和内容来创建通用的在线应用程序)发展的趋势表明计算机用户使用高度集 成的解决方案来利用它们可用的大量信息. 同时,技术优势导致地理服务和设备的发展,包括在线绘制地图解决方案,例如Microsoft Virtual Earth,和较便宜的全球定位系统(GPS)解决方

SQL Server 2008中XML的新增功能

SQL Server 技术文章 作者:Graeme Malcolm(内容主管) 技术审查:Dragan Tomic 和 Michael Rys 项目编辑:Joanne Hodgins 发布日期:2008 年 8 月 适用产品:SQL Server 2008 摘要:Microsoft SQL Server 2008 通过增强对 XML 架构验证和 XQuery 的支持及增加 xml 数据类型,构建对 XML 的广泛支持. 版权 这是一份预备文档,在本文档中所述软件的最终商业版本发布之前,该文档的内

SQL Server 2008中的新日期数据类型

你是否曾经想在数据库中存储一个日期而没有时间部分,或者想存储一个时间值希望有更高的精度?在SQL Server 2008的介绍中,微软介绍了一些新的日期数据类允许你只存储一个日期.更高精度的时间值等.这些新的数据类型为你存储日期和时间相关信息提供了一些附加选项.在本篇文章中,我将介绍这些新的日期数据类型以及与旧版本的SQL Server中现有的数据类型进行比较. 回顾旧的日期数据类型 在我们开始讨论SQL Server 2008中新的日期数据类型之前,先来回顾一下SQL Server 2005中

利用Ring Buffer在SQL Server 2008中进行连接故障排除

原文:利用Ring Buffer在SQL Server 2008中进行连接故障排除 出自:http://blogs.msdn.com/b/apgcdsd/archive/2011/11/21/ring-buffer-sql-server-2008.aspx SQL Server 2008中包含一个新功能,旨在帮助解决特别棘手的连接问题.这个新功能是Connectivity Ring Buffer,它可以捕捉每一个由服务器发起的连接关闭记录(server-initiated connection

SQL Server 2008中的数据表压缩功能详细介绍_mssql2008

SQL Server 2005 SP2为我们带来了vardecimal功能,当时针对decimail和numeric数据类型推出了新的存储格式--vardecimal.vardecimal存储格式允许 decimal和numeric数据类型的存储作为一个可变长度列. 这项功能使得原来定长的decimal数据在数据文件中以可变长的格式存储,据称这项功能可以为典型的数据仓库节省30%的空间,而SQL Server 2008在这一基础上又进一步增强了数据压缩功能.SQL Server 2008现在支持

SQL Server 2008中的数据压缩功能

SQL Server 2005 SP2为我们带来了vardecimal功能,这项功能使得原来定长的decimal数据在数据文件中以可变长的格式存储,据称这项功能可以为典型的数据仓库节省30%的空间,而SQL Server 2008在这一基础上又进一步增强了数据压缩功能.SQL Server 2008现在支持行压缩和页面压缩两种选项,数据压缩选项可以在以下对象上启用: 未创建聚簇索引的表 创建聚簇索引的表 非聚簇索引(对表设置压缩选项不会影响到该表上的非聚簇索引,因此聚簇索引的压缩需要单独设置)

SQL Server 2008中多实例的评估和执行策略

问题提出 了解了SQL Server 2008中的管理策略之后,我们想在SQL Server 2008以及SQL Server 2005中的多实例上执行这些策略.请就如何实现给出详细的解答,谢谢. 专家解答 SQL Server 2008中,当一个实例被创建后,就可以对之进行评估.但数据库管理员需要做一项非常繁琐的工作:SQL Server中所管理的每一个实例都需要逐个执行这些策略.数据库管理员做的最多的工作应该是在产品正式运行前的测试环境中不断地改变执行的策略.然而很多人都并不想逐个逐个的导入

SQL Server 2008中不推荐及不支持的功能

每个人都在等着Microsoft SQL Server 2008的新功能出现,不过我们首先应该知道有哪些"不 推荐(deprecated)"以及"不支持(Discontinued)"的功能."不推荐"的 功能是指那些在旧版SQL Server中出现,但是将会在SQL Server的未来版本中不再推荐使用的功能,并且 在今后的版本中将会去除这些功能."不支持"的功能是指那些不会在SQL Server 2008中出 现的功能.在迁