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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM