搜尋
首頁php教程PHP开发SQLSERVER預存程序傳回遊標的處理

1. 儲存程序返回遊標

Sql代碼 

USE [TEST_DB]  
GO  
  
/****** [PRT].[Move_Data_Return_Cursor]   Script Date: 03/08/2012 17:38:55 ******/  
SET ANSI_NULLS ON  
GO  
  
SET QUOTED_IDENTIFIER ON  
GO  
  
/*********************************************************************************  
*把数据从表 DATA_SOURCE_TABLE 移动到表 TEST_TABLE .  
返回游标供Move_Data_Handle_Cursor供Move_Data_Handle_Cursor存储过程使用.  
*DataServer: 110.110.110.110  
*DataBase:   TEST_DB  
*Name:       [Move_Data_Return_Cursor]  
*Function:     
*Input:      @overTimeHour INT  
*Output:       @CURSOR_PriceChangeRecord CURSOR  
*Creator:    GREATWQS 2012-02-23  
*Updated:    GREATWQS 2012-03-08  UPDATE NEW REQUIREMENT  
**********************************************************************************/  
ALTER PROCEDURE [PRT].[Move_Data_Return_Cursor]   
    -- Add the parameters for the stored procedure here   
    @overTimeHour INT,  
    @CURSOR_PriceChangeRecord CURSOR VARYING OUTPUT  
AS  
  
BEGIN  
      -- SET NOCOUNT ON added to prevent extra result sets from  
      -- interfering with SELECT statements.  
      SET NOCOUNT ON;  
          
      -- print @overTimeHour;  
        
      -- 1. 声明游标: DECLARE CURSOR_PriceChangeRecord  
      SET @CURSOR_PriceChangeRecord = CURSOR  
      FORWARD_ONLY  STATIC    
      FOR   
         SELECT ItemNo,  
                ItemName,  
                ItemColor,  
                ItemSize,  
                ItemMadeIn,  
                InDate   
         FROM   PRT.DATA_SOURCE_TABLE  WITH(NOLOCK)  
         WHERE  InDate > dateadd(HOUR, -@overTimeHour, getdate())  
         -- 在这里进行时间的限定.   
           
    -- 2. 打开游标  
    OPEN @CURSOR_PriceChangeRecord  
      
END

2. 儲存程序處理回遊標 

Sql代碼 

USE [TEST_DB]  
GO  
  
/****** [PRT].[Move_Data_RHandle_Cursor]  Script Date: 03/08/2012 17:39:27 ******/  
SET ANSI_NULLS ON  
GO  
  
SET QUOTED_IDENTIFIER ON  
GO  
  
/*********************************************************************************  
*把数据从表 DATA_SOURCE_TABLE 移动到表 TEST_TABLE  
*把游标中的数据,插入到表TEST_TABLE.  
*DataServer: 110.110.110.110  
*DataBase:   TEST_DB  
*Name:       [Move_Data_Handle_Cursor]  
*Function:     
*Input:      @overTimeHour INT  
*Output:       
*Creator:    GREATWQS 2012-02-23  
*Updated:    GREATWQS 2012-03-08  UPDATE NEW REQUIREMENT  
**********************************************************************************/  
ALTER PROCEDURE [PRT].[Move_Data_Handle_Cursor]   
    -- 超时时间(小时)  
    @overTimeHour INT  
AS  
BEGIN  
    -- SET NOCOUNT ON added to prevent extra result sets from  
    -- interfering with SELECT statements.  
    SET NOCOUNT ON;  
      
    DECLARE  
         -- 需要插入表TEST_TABLE,数据来源声明  
         @ItemNumber_Insert       CHAR(20),  
         @ItemName_Insert         CHAR(50),  
         @ItemColor_Insert        CHAR(10),  
         @ItemSize_Insert         CHAR(5),  
         @ItemWhereMadeIn_Insert  CHAR(20),  
         @createTime_Insert       DATETIME,  
         @changeTime_Insert       DATETIME,  
         @lastChangeTime_Insert   DATETIME,  
         @priority_Insert         INT,  
         @itemType_Insert         INT,  
         @active_Insert           INT,  
         -- ItemNumber Record num in table  
         @totalNum_SelectDB       INT,  
         @changeTime_SelectDB     DATETIME  
      
    -- Set Default Value  
    SET @ItemWhereMadeIn_Insert   = 0  
    SET @createTime_Insert        = getdate()  
    SET @lastChangeTime_Insert    = null  
    SET @priority_Insert          = 0  
    SET @itemType_Insert          = 0  
    SET @active_Insert            = 1  
      
    -- 1. 声明游标: 在过程内部自己定义有游标时,调用游标前面不加@符号  
    DECLARE @CURSOR_Result CURSOR  
        
    -- 2. 得到上个游标, 上个游标已经打开  
    EXEC Move_Data_Return_Cursor @overTimeHour,   
         @CURSOR_PriceChangeRecord = @CURSOR_Result OUTPUT  
        
    -- 3. 抓取游标中的数据: FETCH CURSOR_Result  
    FETCH NEXT  FROM  @CURSOR_Result  
    INTO  @ItemNumber_Insert,   
          @ItemName_Insert,   
          @ItemColor_Insert,   
          @ItemSize_Insert,   
          @changeTime_Insert  
      
    -- 4. 对游标中的每一个记录进行处理: 循环  
    WHILE (@@FETCH_STATUS = 0)  
    BEGIN    
         -- 查看此ItemNumber_Insert是否已经存在表中  
         SELECT TOP 1 @totalNum_SelectDB = COUNT(*)   
         FROM PRT.TEST_TABLE WITH(NOLOCK)  
         WHERE ItemNumber = @ItemNumber_Insert           
           
         -- 如果表不存在此@ItemNumber_Insert, 则插入  
         IF @totalNum_SelectDB = 0  
         BEGIN  
             INSERT INTO PRT.TEST_TABLE(  
                    [ItemNumber],  
                    [ItemName],  
                    [ItemColor],  
                    [ItemSize],  
                    [MadeIn],  
                    [createTime],  
                    [changeTime],  
                    [lastChangeTime],  
                    [priority],  
                    [itemType],  
                    [active])  
              VALUES (   
                    @ItemNumber_Insert,  
                    @ItemName_Insert,  
                    @ItemColor_Insert,  
                    @ItemSize_Insert,  
                    @ItemWhereMadeIn_Insert,  
                    @createTime_Insert,  
                    @changeTime_Insert,  
                    @lastChangeTime_Insert,  
                    @priority_Insert,  
                    @itemType_Insert,  
                    @active_Insert  
                   )  
         END  
         -- 如果此ItemNumber存在于表中  
         ELSE   
         BEGIN  
             -- 查看此ItemNumber_Insert的记录  
             SELECT TOP 1 @changeTime_SelectDB = changeTime  
             FROM PRT.TEST_TABLE WITH(NOLOCK)  
             WHERE ItemNumber = @ItemNumber_Insert  
               
             -- If item has exists in table, and changeTime<=newItem.changeTime   
             -- fresh the changeTime = newItem.changeTime, set active=1;  
             IF @changeTime_SelectDB < @changeTime_Insert    
             BEGIN  
                 UPDATE PRT.TEST_TABLE  
                 SET    changeTime = @changeTime_Insert,   
                        active = 1  
                 WHERE  ItemNumber = @ItemNumber_Insert  
             END  
         END  
           
         -- FETCH NEXT RECORD FROM @CURSOR_Result  
         FETCH NEXT  FROM  @CURSOR_Result  
         INTO  @ItemNumber_Insert,   
               @ItemName_Insert,   
               @ItemColor_Insert,   
               @ItemSize_Insert,   
               @changeTime_Insert  
    END  
      
    -- 5. 关闭游标  
    CLOSE @CURSOR_Result  
      
    -- 6. 删除游标  
    DEALLOCATE @CURSOR_Result      
      
    -- Delete overtime  item, set active=0:changeTime<getdate()-48;  
    UPDATE PRT.TEST_TABLE  
    SET    active=0  
    WHERE  changeTime < dateadd(HOUR, -@overTimeHour, getdate())  
      
END


Sql代碼 🎜rrreee🎜🎜
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)