表A
表B
我想知道用treeview 查询SQL的语句。
表A 中的PI00001....PI00012 对应表B 的V001....VO12
我建立一个Treeview ,PI00001....PI00012是Treeview树的节点,
我想如果我选择PI00001 就能查询到VOO1,以此类推到选择PI00012就能查询到V012
或者全部选择就 能全部查询到V001之V012 !
求教了!

解决方案 »

  1.   

    /*----------------------------------------------
    标题:SQL2005 BOM递归方法整理
    (以公司组织架构为例)整理人:htl258(Tony)日期:2009.04.25(引用请保留此信息)
    ------------------------------------------------*/
    -->创建测试环境
    DECLARE @t TABLE
    (
    FullDept VARCHAR(20), --部门全称
    Dept VARCHAR(20), --部门
    ParentDept VARCHAR(20), --上级部门
    Supervisor VARCHAR(20) --部门主管
    )
    INSERT @t SELECT 'S-IT' ,'IT','S' ,'Peter'
    UNION ALL SELECT 'S-IT-CN' ,'CN','S-IT' ,'Mary' 
    UNION ALL SELECT 'S-IT-CN-SH' ,'SH','S-IT-CN' ,'Jack' 
    UNION ALL SELECT 'S-FS-AP' ,'AP','S-FS' ,'Colin' 
    UNION ALL SELECT 'S-FS' ,'FS','S' ,'Jerry' 
    UNION ALL SELECT 'S' ,'0' ,'0' ,'CiCi' 
    /*
    SELECT * FROM @t
    --------------------
    FullDept(部门全称) Dept(部门) ParentDept(上级部门) Supervisor(部门主管)
    -------------------- -------------------- -------------------- --------------------
    S-IT IT S Peter
    S-IT-CN CN S-IT Mary
    S-IT-CN-SH SH S-IT-CN Jack
    S-FS-AP AP S-FS Colin
    S-FS FS S Jerry
    S 0 0 CiCi
    (6 行受影响)
    */
    -->1.使用CTE递归返回指定根的子树查询:
    --->例1.查询部门主管为"Peter"的所有下级部门清单
    ;WITH t AS 
    (
    SELECT *,0 as lvl /*展开层次*/ FROM @t WHERE Supervisor = 'Peter'
    UNION ALL 
    SELECT a.*,b.lvl+1 FROM @t a /*原表*/ JOIN t b /*CTE*/ ON a.ParentDept = b.FullDept /*原表父项等于CTE子项*/
    )
    SELECT * FROM t ORDER BY FullDept;
    /*
    FullDept Dept ParentDept Supervisor lvl
    -------------------- -------------------- -------------------- -------------------- -----------
    S-IT IT S Peter 0
    S-IT-CN CN S-IT Mary 1
    S-IT-CN-SH SH S-IT-CN Jack 2(3 行受影响)
    */
    --->例2.查询部门主管为"Cici"的所有下级部门清单
    ;WITH t AS 
    (
    SELECT *,0 as lvl /*展开层次*/ FROM @t WHERE Supervisor ='Cici'
    UNION ALL 
    SELECT a.*,b.lvl+1 FROM @t a /*原表*/ JOIN t b /*CTE*/ ON a.ParentDept = b.FullDept /*原表父项等于CTE子项*/
    )
    SELECT * FROM t ORDER BY FullDept;
    /*
    FullDept Dept ParentDept Supervisor lvl
    -------------------- -------------------- -------------------- -------------------- -----------
    S 0 0 CiCi 0
    S-FS FS S Jerry 1
    S-FS-AP AP S-FS Colin 2
    S-IT IT S Peter 1
    S-IT-CN CN S-IT Mary 2
    S-IT-CN-SH SH S-IT-CN Jack 3(6 行受影响)
    */
    -->2.使用CTE递归返回指定子项的父项查询:
    --->例1.查询部门主管为"Jack"的所有上级部门清单
    ;WITH t AS 
    (
    SELECT *,0 as lvl /*展开层次*/ FROM @t WHERE Supervisor = 'Jack'
    UNION ALL 
    SELECT a.*,b.lvl+1 FROM @t a /*原表*/ JOIN t b /*CTE*/ ON b.ParentDept = a.FullDept /*CTE父项等于原表子项*/
    )
    SELECT * FROM t ORDER BY FullDept;
    /*
    FullDept Dept ParentDept Supervisor lvl
    -------------------- -------------------- -------------------- -------------------- -----------
    S 0 0 CiCi 3
    S-IT IT S Peter 2
    S-IT-CN CN S-IT Mary 1
    S-IT-CN-SH SH S-IT-CN Jack 0(4 行受影响)
    */
    --->例2.查询部门主管为"Colin"的所有上级部门清单
    ;WITH t AS 
    (
    SELECT *,0 as lvl /*展开层次*/ FROM @t WHERE Supervisor = 'Colin'
    UNION ALL 
    SELECT a.*,b.lvl+1 FROM @t a /*原表*/ JOIN t b /*CTE*/ ON b.ParentDept = a.FullDept /*CTE父项等于原表子项*/
    )
    SELECT * FROM t ORDER BY FullDept;
    /*
    FullDept Dept ParentDept Supervisor lvl
    -------------------- -------------------- -------------------- -------------------- -----------
    S 0 0 CiCi 2
    S-FS FS S Jerry 1
    S-FS-AP AP S-FS Colin 0(3 行受影响)
    */本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wufeng4552/archive/2010/01/15/5193800.aspx
      

  2.   

    建议不要以发图的方式给测试数据顺便说说你的SQL是2000还是2005,2008?
      

  3.   

    参考这个:/*
    标题:SQL SERVER 2000中查询指定节点及其所有子节点的函数(表格形式显示)
    作者:爱新觉罗·毓华(十八年风雨,守得冰山雪莲花开) 
    时间:2008-05-12
    地点:广东深圳
    */create table tb(id varchar(3) , pid varchar(3) , name varchar(10))
    insert into tb values('001' , null  , '广东省')
    insert into tb values('002' , '001' , '广州市')
    insert into tb values('003' , '001' , '深圳市')
    insert into tb values('004' , '002' , '天河区')
    insert into tb values('005' , '003' , '罗湖区')
    insert into tb values('006' , '003' , '福田区')
    insert into tb values('007' , '003' , '宝安区')
    insert into tb values('008' , '007' , '西乡镇')
    insert into tb values('009' , '007' , '龙华镇')
    insert into tb values('010' , '007' , '松岗镇')
    go--查询指定节点及其所有子节点的函数
    create function f_cid(@ID varchar(3)) returns @t_level table(id varchar(3) , level int)
    as
    begin
      declare @level int
      set @level = 1
      insert into @t_level select @id , @level
      while @@ROWCOUNT > 0
      begin
        set @level = @level + 1
        insert into @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--调用函数查询001(广东省)及其所有子节点
    select a.* from tb a , f_cid('001') b where a.id = b.id order by a.id
    /*
    id   pid  name       
    ---- ---- ---------- 
    001  NULL 广东省
    002  001  广州市
    003  001  深圳市
    004  002  天河区
    005  003  罗湖区
    006  003  福田区
    007  003  宝安区
    008  007  西乡镇
    009  007  龙华镇
    010  007  松岗镇(所影响的行数为 10 行)
    */--调用函数查询002(广州市)及其所有子节点
    select a.* from tb a , f_cid('002') b where a.id = b.id order by a.id
    /*
    id   pid  name       
    ---- ---- ---------- 
    002  001  广州市
    004  002  天河区(所影响的行数为 2 行)
    */--调用函数查询003(深圳市)及其所有子节点
    select a.* from tb a , f_cid('003') b where a.id = b.id order by a.id
    /*
    id   pid  name       
    ---- ---- ---------- 
    003  001  深圳市
    005  003  罗湖区
    006  003  福田区
    007  003  宝安区
    008  007  西乡镇
    009  007  龙华镇
    010  007  松岗镇(所影响的行数为 7 行)
    */drop table tb
    drop function f_cid@@ROWCOUNT:返回受上一语句影响的行数。
    返回类型:integer。
    注释:任何不返回行的语句将这一变量设置为 0 ,如 IF 语句。
    示例:下面的示例执行 UPDATE 语句并用 @@ROWCOUNT 来检测是否有发生更改的行。UPDATE authors SET au_lname = 'Jones' WHERE au_id = '999-888-7777'
    IF @@ROWCOUNT = 0
       print 'Warning: No rows were updated'结果:(所影响的行数为 0 行)
    Warning: No rows were updated
      

  4.   


    /*
    标题:SQL SERVER 2005中查询指定节点及其所有子节点的方法(表格形式显示)
    作者:爱新觉罗·毓华(十八年风雨,守得冰山雪莲花开) 
    时间:2010-02-02
    地点:新疆乌鲁木齐
    */create table tb(id varchar(3) , pid varchar(3) , name nvarchar(10))
    insert into tb values('001' , null  , N'广东省')
    insert into tb values('002' , '001' , N'广州市')
    insert into tb values('003' , '001' , N'深圳市')
    insert into tb values('004' , '002' , N'天河区')
    insert into tb values('005' , '003' , N'罗湖区')
    insert into tb values('006' , '003' , N'福田区')
    insert into tb values('007' , '003' , N'宝安区')
    insert into tb values('008' , '007' , N'西乡镇')
    insert into tb values('009' , '007' , N'龙华镇')
    insert into tb values('010' , '007' , N'松岗镇')
    goDECLARE @ID VARCHAR(3)--查询ID = '001'的所有子节点
    SET @ID = '001'
    ;WITH T AS
    (
      SELECT ID , PID , NAME 
      FROM TB
      WHERE ID = @ID
      UNION ALL
      SELECT A.ID , A.PID , A.NAME 
      FROM TB AS A JOIN T AS B ON A.PID = B.ID
    )
    SELECT * FROM T ORDER BY ID
    /*
    ID   PID  NAME
    ---- ---- ----------
    001  NULL 广东省
    002  001  广州市
    003  001  深圳市
    004  002  天河区
    005  003  罗湖区
    006  003  福田区
    007  003  宝安区
    008  007  西乡镇
    009  007  龙华镇
    010  007  松岗镇(10 行受影响)
    */--查询ID = '002'的所有子节点
    SET @ID = '002'
    ;WITH T AS
    (
      SELECT ID , PID , NAME 
      FROM TB
      WHERE ID = @ID
      UNION ALL
      SELECT A.ID , A.PID , A.NAME 
      FROM TB AS A JOIN T AS B ON A.PID = B.ID
    )
    SELECT * FROM T ORDER BY ID
    /*
    ID   PID  NAME
    ---- ---- ----------
    002  001  广州市
    004  002  天河区(2 行受影响)
    */--查询ID = '003'的所有子节点
    SET @ID = '003'
    ;WITH T AS
    (
      SELECT ID , PID , NAME 
      FROM TB
      WHERE ID = @ID
      UNION ALL
      SELECT A.ID , A.PID , A.NAME 
      FROM TB AS A JOIN T AS B ON A.PID = B.ID
    )
    SELECT * FROM T ORDER BY ID
    /*
    ID   PID  NAME
    ---- ---- ----------
    003  001  深圳市
    005  003  罗湖区
    006  003  福田区
    007  003  宝安区
    008  007  西乡镇
    009  007  龙华镇
    010  007  松岗镇(7 行受影响)
    */drop table tb--注:除ID值不一样外,三个SQL语句是一样的。
      

  5.   

    我的是SQL 2005 在VS 2005上 用的是VB.NET
      

  6.   

    两个表不就是多了个连接么??一样的嘛测试数据指的是tb
    col1 col2
    a     1
    b     2
    c     3这样的
      

  7.   

    我发下测试数据:
    TB1 :                                                             
    pointname                               
    p000001
    p000002
    p000003
    p000004
    p000005
    p000006
    p000007
    p000008
    p000009
    p000010
    p000011
    p000012
    TB2
    V001 V002 V003 V004 V005 V006 V007 V008 V009 V010 V011 V012
    1      2    3    4    5    6    7    8    9    10   11   12