|
或多或少都做过树状目录、产品分类之类的二级或三级菜单,如果遇到更多级的分类,就一般使用递归了。在程序中使用递归或多或少会增加一些性能上的开销。
之前我用ASP.net在程序中实现过非递归的无限级分类目录,但考虑到移植性不强,就改成了存储过程,发出来大家共同研究一下,到目前为止,测试过程中还没发现问题,另外,代码方面没经过什么优化。
通常情况下,我们更多的操作是读取目录,所以,在下面的实现中,读取我们只需要一Select语句就够了,不使用递归,理论上无限级~! =================================================== 表结构: 表名:Tb_Column 表结构(所有字段非空): Column_ID int 主键(注:非标识) Column_Name nvarchar(50)分类名称 Parent_ID int 父分类ID(默认值0) Column_Path nvarchar(1000) 分类路径 Column_Depth int分类深度(默认值0) Column_Order int排序(默认值0) Column_Intro nvarchar(1000)分类说明
================================================ 存储过程一:新建分类
CREATE PROCEDURE sp_Column_Insert ( @Parent_ID int, @Column_Name nvarchar(50), @Column_Intro nvarchar(1000) ) AS Declare @Err As int Set @Err=0
Begin Tran --通过现有记录获取栏目ID Declare @Column_ID As int Declare @Column_Depth As int Select @Column_ID = Max(Column_ID) From Tb_Column IF @Column_ID Is Not Null Set @Column_ID = @Column_ID+1 Else Set @Column_ID = 1
--判断是否是顶级栏目,设置其Column_Path和Column_Order Declare @Column_Path As nvarchar(1000) Declare @Column_Order As int IF @Parent_ID = 0 Begin Set @Column_Path =Ltrim(Str(@Column_ID)) Select @Column_Order = Max(Column_Order) From Tb_Column IF @Column_Order Is Not Null Set @Column_Order = @Column_Order + 1 Else --如果没有查 [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] 下一页
|