好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > sqlserver 存儲過程帶事務 拼接id 返回值

sqlserver 存儲過程帶事務 拼接id 返回值

熱門標簽:400電話申請需要開戶費嗎 重慶防封電銷機器人供應商 北京辦理400電話多少 溫州語音外呼系統代理 威海智能語音外呼系統 西安青牛防封電銷卡 南京電銷外呼系統運營商 山西語音外呼系統價格 智能語音外呼系統哪個牌子好
刪除一條留言信息會級聯刪除回復信息,這時我們需要用到事務,如下SQL
復制代碼 代碼如下:

ALTER PROCEDURE [dbo].[proc_tb_leaveword_delete]
 (
     @leavewordID INT,
     @record TINYINT OUTPUT
 )   
 AS
 BEGIN
     BEGIN TRY
         BEGIN TRANSACTION
             DELETE FROM tb_leavewordID WHERE leavewordID=@leavewordID
             DELETE FROM tb_reply WHERE leavewordID=@leavewordID
             SET @record=0 --成功
             COMMIT TRANSACTION
     END TRY
     BEGIN CATCH
         ROLLBACK TRANSACTION
         SET @record=-1 --失敗
     END CATCH
     RETURN @record
 END

刪除一條新聞,一條新聞可能有多條留言,每條留言可能有回復信息,這時我們刪除一條新聞的SQL如下
復制代碼 代碼如下:

ALTER PROCEDURE [dbo].[proc_tb_news_delete]
 (
     @newsID INT,
     @record TINYINT OUTPUT
 )   
 AS
 BEGIN
     DECLARE @leavewordCount INT --留言個數
     DECLARE @delete_where VARCHAR(4000) --留言id字符,類似1,2,4,5,6
     SET @leavewordCount=(SELECT ISNULL(COUNT(1),0) FROM tb_leaveword WHERE newsID=@newsID)
     SET @delete_where=''
     IF(@leavewordCount=0) --此條新聞無留言時
         BEGIN TRY
             DELETE FROM tb_news WHERE newsID=@newsID
             SET @record=0 --成功
         END TRY
         BEGIN CATCH
             SET @record=-1 --失敗
         END CATCH
     ELSE IF(@leavewordCount>0) --此條新聞有留言時
        ----獲取刪除條件(start)----
        DECLARE MY_CURSOR CURSOR
        FOR SELECT leavewordID FROM tb_news WHERE newsID=@newsID
        BEGIN
            DECLARE @leavewordID INT
            OPEN MY_CURSOR
            FETCH NEXT FROM MY_CURSOR INTO @leavewordID
            IF(@leavewordID IS NOT NULL)
                SET @delete_where=@delete_where+CAST(@leavewordID AS VARCHAR(10))+','
                WHILE(@@FETCH_STATUS>-1)
                    BEGIN
                        SET @leavewordID=NULL
                        FETCH NEXT FROM MY_CURSOR INTO @leavewordID
                        IF(@leavewordID IS NOT NULL)
                            SET @delete_where=@delete_where+CAST(@leavewordID AS VARCHAR(10))+','
                    END
         END
         CLOSE MY_CURSOR
         DEALLOCATE MY_CURSOR
         SET @delete_where=SUBSTRING(@delete_where,1,LEN(@delete_where)-1)
         ----獲取刪除條件(end)----
         BEGIN
             BEGIN TRY
                 BEGIN TRANSACTION
                     DELETE FROM tb_news WHERE newsID=@newsID
                     EXECUTE('DELETE FROM tb_leaveword WHERE leavewordID IN('+@delete_where+')')
                     EXECUTE('DELETE FROM tb_reply WHERE leavewordID IN('+@delete_where+')')
                     SET @record=0 --成功
                     COMMIT TRANSACTION
             END TRY
             BEGIN CATCH
                 ROLLBACK TRANSACTION
                 SET @record=-1 --失敗
             END CATCH
         END
      RETURN @record
 END

刪除一新聞類型時,可能此類型下有多條新聞,此條新聞下又有多條留言,留言下又有多條回復,依次級聯刪除,如下存儲過程
復制代碼 代碼如下:

ALTER PROCEDURE [dbo].[proc_tb_news_type_delete]
 (
     @typeID INT,
     @record TINYINT OUTPUT
 )
 AS
 BEGIN
     DECLARE @newsCount INT --此類新聞下的新聞個數
     SET @newsCount=(SELECT ISNULL(COUNT(1),0) FROM tb_news WHERE typeID=@typeID)
     IF(@newsCount=0) --此類型下無新聞
         BEGIN TRY
             DELETE FROM tb_news_type WHERE typeID=@typeID
             SET @record=0 --成功
         END TRY
         BEGIN CATCH
             SET @record=-1 --失敗
         END CATCH
     ELSE IF(@newsCount>0) --此類型下有新聞
         BEGIN TRY
             BEGIN TRANSACTION
                 DECLARE MY_CURDOR CURSOR
                 FOR SELECT newsID FROM tb_news WHERE typeID=@typeID
                 BEGIN
                     DECLARE @newsID INT
                     OPEN MY_CURSOR
                     FETCH NEXT FROM MY_CURSOR INTO @newsID
                     IF(@newsID IS NOT NULL)
                         DELETE FROM tb_news_type WHERE typeID=@typeID
                         EXECUTE proc_tb_news_delete @newsID=@newsID --執行存儲過程
                         WHILE(@@FETCH_STATUS>-1)
                             BEGIN
                                 SET @newsID=NULL
                                 FETCH NEXT FROM MY_CURSOR INTO @newsID
                                 IF(@newsID IS NOT NULL)
                                     DELETE FROM tb_news_type WHERE typeID=@typeID
                                     EXECUTE proc_tb_news_delete @newsID=@newsID --執行存儲過程
                             END
                 END
                 CLOSE MY_CURSOR
                 DEALLOCATE MY_CURSOR
                 COMMIT TRANSACTION
         END TRY
         BEGIN CATCH
             ROLLBACK TRANSACTION
             SET @record=-1 --失敗
         END CATCH
      RETURN @record
 END

當刪除多條新聞類型時,我們需要把拼接好的類型id,例如:1,2,4,5,12,34,穿入存儲過程,分割字符的SQL語句如下所示:
復制代碼 代碼如下:

DECLARE @A VARCHAR(5000)
 DECLARE @i INT
 SET @A='A,B,C,D,D,S,X,C,C,C,D,AAAA,DDDDDD,DEF,ERT,'
 SET @i=CHARINDEX(',',@A)
 WHILE @i>=1
 BEGIN
     PRINT LEFT(@A,@i-1)
     SET @A=SUBSTRING(@A,@i+1,LEN(@A)-1)
     SET @i=CHARINDEX(',',@A)
 END

刪除多條新聞類型SQL如下:
復制代碼 代碼如下:

ALTER PROCEDURE [dbo].[proc_tb_news_type_selects_delete]
 (
     @typeID_list VARCHAR(500),
     @record TINYINT OUTPUT
 )
 AS
 BEGIN
     BEGIN TRY
             BEGIN TRANSACTION
                 DECLARE @index INT
                 DECLARE @typeID INT
                 SET @typeID_list=RTRIM(LTRIM(@typeID_list))
                 SET @index=CHARINDEX(',',@typeID_list)
                 WHILE @index>=1
                     BEGIN
                         SET @typeID=CAST(LEFT(@typeID_list,@index-1) AS INT)
                         EXECUTE proc_tb_news_type_delete @typeID=@typeID
                         SET @typeID_list=SUBSTRING(@typeID_list,@index+1,LEN(@typeID_list)-1)
                         SET @index=CHARINDEX(',',@typeID_list)
                     END
             COMMIT TRANSACTION
             SET @record=0 --成功
     END TRY
     BEGIN CATCH
         ROLLBACK TRANSACTION
         SET @record=-1 --失敗
     END CATCH
     RETURN @record
 END

作者:cnblogs xu_happy_you
您可能感興趣的文章:
  • SqlServer存儲過程實現及拼接sql的注意點
  • sqlServer實現去除字符串空格
  • sqlserver,sqlite,access數據庫鏈接字符串整理
  • sqlserver、mysql獲取連接字符串步驟
  • SQLSERVER 拼接含有變量字符串案例詳解

標簽:濟寧 河源 金昌 貸款群呼 黃山 新余 宜春 中衛

巨人網絡通訊聲明:本文標題《sqlserver 存儲過程帶事務 拼接id 返回值》,本文關鍵詞  sqlserver,存儲,過程,帶,事務,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《sqlserver 存儲過程帶事務 拼接id 返回值》相關的同類信息!
  • 本頁收集關于sqlserver 存儲過程帶事務 拼接id 返回值的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 男男肉文推荐| 男人桶女人桶到爽免费观看动漫| 日本免费三片在线播放| 古代高H禁伦亲子| 日本5级床片全免费| 我的小后妈中文翻译| [3D全彩H漫]丝袜人妻 | 日韩精品第一页| 寂寞难耐的浪荡艳妇| 911精品国自产在线偷拍| 国产免费女女脚奴视频网| 成年黄网站在线观看| 麻豆传煤适当放松一下自己| 欧洲码日本码专线| 被cao的喷水| 精精国产XXXX视频线观看| 开心激情在线| 国产麻豆入在线观看| a级日本片在线观看| 最美情侣韩剧免费观看| 扒开内裤趴着女人打屁股| 女同19禁啪啪无遮挡免费| 高潮捣出白浆嗯啊哭叫H漫画| 动漫被吸乳羞羞漫画| 怀远县| 浓毛少妇A片久久曰| 亚洲成a人片在线观看网站男男| 菠萝菠萝蜜高清观看3| 乖宝真紧H太好c了h| 人人爱91精品偷拍亚洲| 东港市| 肌肌桶肤肤| 第一次按摩推油高潮经历| 秋霞电影午夜| 成人综合久久综合| 办公室被主人狠狠道具调教| 胸?啊?嗯~丝袜下面出水了动漫 | 一级做a爰片毛片???| 精品国产欧美片一区二区免费 | 国产免费无码一区二区Av视频| 男人狂揉吃奶胸视频|