zoukankan      html  css  js  c++  java
  • sql 双层游标嵌套

       --创建存储数据临时表

      CREATE TABLE Temp_Dep(TEMP_depid varchar(50),TEMP_depname VARCHAR(50),TEMP_NAME varchar(5000))

       --向临时表中插入前三列数据

       INSERT INTO Temp_Dep(TEMP_depid,TEMP_depname) SELECT DISTINCT A.DEPT_NO,B.DEPT_NOTE FROM dbo.HES_EMPLOYEE A JOIN dbo.HES_DEPT

      B ON A.DEPT_NO = B.DEPT_NO WHERE STATUS IN ('zaizhi','shiyong')

        --创建查询小组编号的游标

        DECLARE Somedepid_cusor CURSOR FOR

        SELECT DISTINCT TEMP_depid FROM Temp_Dep

       OPEN  Somedepid_cusor

       FETCH NEXT FROM Somedepid_cusor INTO @TEMP_depid

       WHILE @@FETCH_STATUS=0

       BEGIN

            --创建查询员工数据游标

            SET @TEMP_SomeNAME=''

            DECLARE SomeNAME_cusor CURSOR FOR

             SELECT NAME FROM dbo.HES_EMPLOYEE WHERE DEPT_NO=@TEMP_depid AND STATUS IN ('zaizhi','shiyong')

            OPEN  SomeNAME_cusor

            FETCH NEXT FROM SomeNAME_cusor INTO @TEMP_NAME

            WHILE @@FETCH_STATUS=0

            BEGIN

                SET  @TEMP_SomeNAME=RTRIM(@TEMP_SomeNAME)+RTRIM(@TEMP_NAME)+','

                FETCH NEXT FROM SomeNAME_cusor INTO @TEMP_NAME

            END

            CLOSE SomeNAME_cusor

            DEALLOCATE SomeNAME_cusor

           --更新数据

          UPDATE dbo.Temp_Dep SET TEMP_NAME=@TEMP_SomeNAME WHERE TEMP_depid=@TEMP_depid

          FETCH NEXT FROM Somedepid_cusor INTO @TEMP_depid

       END

       CLOSE Somedepid_cusor

       DEALLOCATE Somedepid_cusor

      --查询数据

       SELECT * FROM Temp_Dep

  • 相关阅读:
    C++11中右值引用和移动语义
    面试题3:自己实现单链表
    C++中指针和引用、数组之间的区别
    C++中对象模型
    C++中虚函数的动态绑定和多态性
    C++11中多线程库
    C++中友元
    C++中迭代器原理、失效和简单实现
    C++11中智能指针的原理、使用、实现
    C++中模板与泛型编程
  • 原文地址:https://www.cnblogs.com/dekevin/p/2493478.html
Copyright © 2011-2022 走看看