千家信息网

SQL Server 2008中有哪些分层数据类型

发表于:2024-11-29 作者:千家信息网编辑
千家信息网最后更新 2024年11月29日,这篇文章给大家介绍SQL Server 2008中有哪些分层数据类型,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。SQLServer2008原生的分层数据类型有哪些假如是在SQL
千家信息网最后更新 2024年11月29日SQL Server 2008中有哪些分层数据类型

这篇文章给大家介绍SQL Server 2008中有哪些分层数据类型,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

  SQLServer2008原生的分层数据类型有哪些

  假如是在SQLServer2000中,我们需要读取分层结构数据时,不得不借助递归。在SQLserver2005中,我们可以使用CTE,当然,好的数据结构设计可以避免你使用CTE,请看这里:http://www.cnblogs.com/downmoon/archive/2009/10/23/1588405.html。

  假如你是一个数据库设计新手,那么在sqlserver2008中可以使用新的原生分层结构数据hierarchyid。

  关于它的详细说明,请看MSDN:

  http://msdn.microsoft.com/zh-cn/library/bb677173%28v=sql.100%29.aspx

  http://64.4.11.252/zh-cn/library/bb677173.aspx

  http://msdn.microsoft.com/en-us/magazine/cc794278.aspx#id0090037

  需要注意的是,它可以改造传统数据表而成。但不可以实现与XML互相转换。

  SQLServer2008原生的分层数据类型有哪些

  下面我们看一个示例:

  ifOBJECT_ID('[Category_hierarchyid]')isnotnulldroptable[Category_hierarchyid]go--创建表CREATETABLE[Category_hierarchyid](H_IDhierarchyidNOTNULL,C_IDINTprimarykeyidentity(1000,1)NOTNULL,C_NameNVARCHAR(50)NOTNULL,TitleNVARCHAR(50)NOTNULL)GOTRUNCATEtable[Category_hierarchyid]GOINSERTINTO[Category_hierarchyid]([H_ID],[C_Name],[Title])select'/','蔬菜','蔬菜'unionallselect'/1/','根菜类','蔬菜'unionallselect'/2/','叶菜类','蔬菜'unionallselect'/3/','茄果类','蔬菜'unionallselect'/4/','甘蓝类','蔬菜'unionallselect'/1/1/','萝卜','蔬菜'unionallselect'/1/1/','胡萝卜','蔬菜'unionallselect'/4/2/','甘蓝','蔬菜'unionallselect'/2/4/','花椰菜','蔬菜'unionallselect'/3/3/','茄子','蔬菜'unionallselect'/3/3/','番茄','蔬菜'unionALLselect'/1/1/5/','白萝卜','蔬菜'go

  SQLserver2008中的原生分层数据:hierarchyid

  --查看所有的分类

  SELECT*FROM[Category_hierarchyid]/*H_IDC_IDC_NameTitle0x1000蔬菜蔬菜0x581001根菜类蔬菜0x681002叶菜类蔬菜0x781003茄果类蔬菜0x841004甘蓝类蔬菜0x5AC01005萝卜蔬菜0x5AC01006胡萝卜蔬菜0x85A01007甘蓝蔬菜0x6C201008花椰菜蔬菜0x7BC01009茄子蔬菜0x7BC01010番茄蔬菜0x5AE31011白萝卜蔬菜*/

  --查看所有的分类及级别

  SELECT*,H_ID.GetLevel()ASLevelFROM[Category_hierarchyid]/*H_IDC_IDC_NameTitleLevel0x1000蔬菜蔬菜00x581001根菜类蔬菜10x681002叶菜类蔬菜10x781003茄果类蔬菜10x841004甘蓝类蔬菜10x5AC01005萝卜蔬菜20x5AC01006胡萝卜蔬菜20x85A01007甘蓝蔬菜20x6C201008花椰菜蔬菜20x7BC01009茄子蔬菜20x7BC01010番茄蔬菜20x5AE31011白萝卜蔬菜3*/

  --查看根菜类及其子分类

  DECLARE@ParenthierarchyidSELECT@Parent=H_IDFROM[Category_hierarchyid]WHEREC_ID=1001----PRINT@Parent.ToString()SELECT*,H_ID.GetLevel()ASLevelFROM[Category_hierarchyid]WHEREH_ID.IsDescendantOf(@Parent)=1/*H_IDC_IDC_NameTitleLevel0x581001根菜类蔬菜10x5AC01005萝卜蔬菜20x5AC01006胡萝卜蔬菜20x5AE31011白萝卜蔬菜3*/

  --查看胡萝卜及其所有父分类

  DECLARE@SonhierarchyidSELECT@Son=H_IDFROM[Category_hierarchyid]WHEREC_ID=1006SELECT*,H_ID.GetLevel()ASLevelFROM[Category_hierarchyid]WHERE@Son.IsDescendantOf(H_ID)=1/*H_IDC_IDC_NameTitleLevel0x1000蔬菜蔬菜00x581001根菜类蔬菜10x5AC01005萝卜蔬菜20x5AC01006胡萝卜蔬菜2*/。

关于SQL Server 2008中有哪些分层数据类型就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

0