无限分级的数据查询是个头痛的问题,递归查询类别,再组合成字符串,用 in 来解决子类所有产品的问题,但是这个效率太低,低的让人无法接受,在此,有一个SQL的方法,可让我们提高效率。
-----提取子类的所有类别ID
create function GetChild (@id int)
returns @t table(id int)
as
begin
insert @t select classid from mproclass where parentid = @id
while @@rowcount > 0
insert @t select a.classid from mproclass as a inner join @t as b
on a.parentid = b.id and a.classid not in(select id from @t)
return
end
-----提取子类以及自己ID的所有类别ID
create function GetChildAndSelf (@id int)
returns @t table(id int)
as
begin
insert @t values (@id)
insert @t select classid from mproclass where parentid = @id
while @@rowcount > 0
insert @t select a.classid from mproclass as a inner join @t as b
on a.parentid = b.id and a.classid not in(select id from @t)
return
end
以上是最佳方案
查询该类别的产品数据的sql为:
sql = "select * from mProduct as a inner join (select [id] from GetChildAndSelf("+classid+")) as b on a.classid=b.id order by psortid desc,pdate desc";
太爽了!
网上还有其他几种方法,贴出来大家一起学习学习
一、
declare @table table(id int,upperid int)
insert into @table
select 1, 2
union all select 3, 2
union all select 4, 1
union all select 5, 3
declare @upperid int
set @upperid=2;
with result(id,upperid)
as
(
select id,upperid from @table where upperid=@upperid
union all
select a.id,a.upperid from @table a inner join result b on a.upperid=b.id
)
select*from result
/*
id upperid
----------- -----------
1 2
3 2
5 3
4 1
(4 row(s) affected)
*/
二、
Create table t(id int,upperid int)
insert into t
select 1, 2
union all select 3, 2
union all select 4, 1
union all select 5, 3
select * from t
create function aa(@upperid int)
returns @t table (id int,upperid int,level int)
as
begin
declare @i int
set @i=1
insert into @t
select *,@i from t where upperid=@upperid
while @@rowcount> 0
begin
set @i=@i+1
insert into @t
select a.*,@i from t a left join @t b on a.upperid=b.id
where b.level=@i-1
end
return
end
select * from dbo.aa(1)
id upperid level
----------- ----------- -----------
4 1 1
(所影响的行数为 1 行)
select * from dbo.aa(2)
id upperid level
----------- ----------- -----------
1 2 1
3 2 1
4 1 2
5 3 2
三、
----创建测试数据
if object_id( 'tbTest ') is not null
drop table tbTest
if object_id( 'spGetChildren ') is not null
drop proc spGetChildren
GO
create table tbTest(id int, upperid int)
insert tbTest
select 1, 2 union all
select 3, 2 union all
select 4, 1 union all
select 5, 3
GO
----创建存储过程
create proc spGetChildren @id int
as
declare @t table(id int)
insert @t select id from tbTest where upperid = @id
while @@rowcount > 0
insert @t select a.id from tbTest as a inner join @t as b
on a.upperid = b.id and a.id not in(select id from @t)
select * from @t
GO
----执行存储过程
declare @upperid int
set @upperid = 2
EXEC spGetChildren @upperid
----清除测试环境
drop proc spGetChildren
drop table tbTest
/*结果
id
-----------
1
3
4
5
*/
[ZT http://www.cnblogs.com/skylaugh/archive/2008/06/03/1213133.html]
分享到:
相关推荐
易语言Access版本易语言树型框无限分级.rar 易语言Access版本易语言树型框无限分级.rar 易语言Access版本易语言树型框无限分级.rar 易语言Access版本易语言树型框无限分级.rar 易语言Access版本易语言树型框无限...
TreeView&XML实现无限分级,递归实现无限分级,无论在xml文件中添加几级都可以实现.
Access版本树型框无限分级.rar
树的递归无限分级,有数据库,环境是vs2010。方法是递归调用。
Js写的一个无限分级的树结构,在web开发中很实用!
Access版本易语言树型框无限分级
多用户无限分级的模拟文件管理系统 多用户无限分级的模拟文件管理系统 多用户无限分级的模拟文件管理系统
WPF Treeview 无限分级绑定集合数据 (1)
Winform TreeView控件无限分级绑定数据&获取选项
zencart左边导航菜单插件,功能很强大,可以无限分级,用无限递归思想实现,值得大家去研究
把多级菜单用一份语句查询出来 如 1---- 1.1-- 1.2-- 2---- 2.1-- 2.2--
无限分级 面向对象的方式 从数据库中读取节点后,只要一句代码,如用JSP (rs.next()){ %> d.add(("id")%>,("pid")%>,'("title")%>'); <% }%>
dtree显示无限分级树,树的增删改,myeclipse8.0工程,SQL SERVER2000数据库
无限分级下拉列表(无刷新),ajax部分用的是jquery的,但是语法还是javascript,服务器处理数据用的是webservice,为了使大家更容易理解,就没有进行数据操作的封装。
推进分级诊疗制度 优化医疗资源配置.pdf
PHP树结构,实现无限分级 代码亲测有效,放在php环境下就行
易语言源码Access版本树型框无限分级.rar
Access版本易语言树型框无限分级.zip易语言项目例子源码下载Access版本易语言树型框无限分级.zip易语言项目例子源码下载 1.合个人学习技术做项目参考 2.适合学生做毕业设计参考 3.适合小团队开发项目参考
田庄选煤厂针对原粗煤泥分级系统中存在的问题,选用6台550mm高效分级旋流器与角锥沉淀池及脱泥筛组合,建立了6套独立的以旋流器为主要分级设备的粗煤泥分级子系统;利用PLC技术实现了粗煤泥分级系统的集中控制;利用...
基于xml的无限分级树的应用研究,王盛,,无论是在Web开发还是应用程序开发过程中,采用树型结构显示某个功能,甚至架构整个系统,对用户而言是既方便,又直观,但运用无限