这篇文章给大家介绍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中有哪些分层数据类型就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。