item表(明细表):model(主键),name,info
tree表(结构表):id,model,num,pid
tree表就是通常的多级结构表(pid存放id),这里意思是有 num 个 model型号的物料组成上一级。
问题:
输入一个pid,查询该 id物料 由哪些 下级物料 组成,并列出 num,name,info
我的思路是:先查出
Select [model],[num] from [tree] where [pid]=" + PID ;
再根据model连接name info
新手,想不出怎么写。高手指教,谢谢。
BOM。。。
SQL code:
---------------------------
--就用树型表,可到N级.参考如下:
create table tb(id int, name varchar(10), pid int, px int)
insert into tb values(0 , '栏目分类', 0 , 1)
insert into tb values(1 , '动物' , 0 , 1)
insert into tb values(2 , '视频' , 0 , 2)
insert into tb values(3 , '老虎' , 1 , 1)
insert into tb values(4 , '狮子' , 1 , 2)
insert into tb values(5 , '搞笑' , 2 , 1)
go
--查询指定节点及其所有子节点的函数
CREATE FUNCTION f_Cid(@ID int) RETURNS @t_Level TABLE(ID int,Level int)
AS
BEGIN
DECLARE @Level int
SET @Level=1
INSERT @t_Level SELECT @ID,@Level
WHILE @@ROWCOUNT>0
BEGIN
SET @Level=@Level+1
INSERT @t_Level SELECT a.ID,@Level
from tb a,@t_Level b
WHERE a.PID=b.ID
AND b.Level=@Level-1
END
RETURN
END
GO
--调用函数查询id = 1及其所有子节点
SELECT a.* from tb a,f_
可能因为工作的原因 接触数据库这块比较少,之前都是做程序这块,数据库这块都有专门的人来做 分工都很明细 所以对数据库这一块完全不了解。前段时间 去面试了几家公司 几乎都是在数据库这块挂掉的 连个简单的SQ ......