亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

【SQL】找出行數與自增標識值不相等的表(即有

系統 1966 0
原文: 【SQL】找出行數與自增標識值不相等的表(即有缺行)

環境: mssql ent 2k8 r2

原理: 遍歷所有含自增列的用戶表,用sp_spaceused過程分別獲取每張表的行數并寫入臨時表,然后使用IDENT_CURRENT函數獲取表的最大標識值,比較二者并返回結果

      
        
          IF
        
        
          OBJECT_ID
        
        (
        
          '
        
        
          tempdb..#TableRowCount
        
        
          '
        
        ,
        
          '
        
        
          U
        
        
          '
        
        ) 
        
          IS
        
        
          NOT
        
        
          NULL
        
        
          DROP
        
        
          TABLE
        
        
           #TableRowCount 
        
        
          GO
        
        
          CREATE
        
        
          TABLE
        
         #TableRowCount (Name sysname 
        
          PRIMARY
        
        
          KEY
        
        , RowCnt 
        
          DECIMAL
        
        (
        
          11
        
        ,
        
          0
        
        ), Reserved 
        
          VARCHAR
        
        (
        
          18
        
        ), Data 
        
          VARCHAR
        
        (
        
          18
        
        ), Index_Size 
        
          VARCHAR
        
        (
        
          18
        
        ), Unused 
        
          VARCHAR
        
        (
        
          18
        
        
          )) 
        
        
          GO
        
        
          DECLARE
        
         curCntAllTableRows 
        
          CURSOR
        
         LOCAL FAST_FORWARD 
        
          FOR
        
        
          SELECT
        
         name 
        
          FROM
        
         sys.tables 
        
          WHERE
        
        
          OBJECTPROPERTY
        
        (
        
          object_id
        
        ,
        
          '
        
        
          TableHasIdentity
        
        
          '
        
        )
        
          =
        
        
          1
        
        
          OPEN
        
        
           curCntAllTableRows 
        
        
          DECLARE
        
        
          @TableName
        
        
           sysname 
        
        
          FETCH
        
        
          NEXT
        
        
          FROM
        
         curCntAllTableRows 
        
          INTO
        
        
          @TableName
        
        
          WHILE
        
        
          @@FETCH_STATUS
        
        
          =
        
        
          0
        
        
          BEGIN
        
        
          INSERT
        
        
          INTO
        
         #TableRowCount 
        
          EXEC
        
         sys.sp_spaceused 
        
          @TableName
        
        
          FETCH
        
        
          NEXT
        
        
          FROM
        
         curCntAllTableRows 
        
          INTO
        
        
          @TableName
        
        
          END
        
        
          CLOSE
        
        
           curCntAllTableRows 
        
        
          DEALLOCATE
        
        
           curCntAllTableRows 
        
        
          /*
        
        
          由于IDENT_CURRENT對于空表也會返回1,所以做特別處理
        
        
          */
        
        
          WITH
        
         cteA 
        
          AS
        
        
           ( 
        
        
          SELECT
        
         Name,RowCnt,
        
          CASE
        
         IDENT_CURRENT(Name) 
        
          WHEN
        
        
          1
        
        
          THEN
        
         RowCnt 
        
          ELSE
        
         IDENT_CURRENT(Name) 
        
          END
        
        
          AS
        
        
          '
        
        
          CurrID
        
        
          '
        
        
          FROM
        
        
           #TableRowCount ) 
        
        
          SELECT
        
        
           Name,RowCnt,CurrID 
        
        
          FROM
        
        
           cteA 
        
        
          WHERE
        
         RowCnt
        
          <>
        
        CurrID
      
    

文畢。

?

【SQL】找出行數與自增標識值不相等的表(即有缺行)


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产亚洲精品国看不卡 | 日日夜夜精品免费视频 | 国产一级毛片夜一级毛片 | 亚洲精品综合一区二区三区在线 | 四虎国产精品4hu永久 | 亚洲精品久久九九精品 | 亚洲欧美综合人成野草 | 青草福利在线 | 91亚洲精品一区二区在线观看 | 亚洲综合图片人成综合网 | 草莓视频在线观看精品最新 | 中文字幕曰韩一区二区不卡 | 久热国产视频 | 午夜91视频| 好好的日com欧美 | 日本高清在线观看天码888 | 日韩成人免费在线视频 | 在线观看 中文字幕 | 国产精品久久久久久久9999 | 97在线观看完整免费 | 韩国19禁青草福利视频在线 | 欧美在线看片 | 午夜亚洲国产精品福利 | 日日干日日操日日射 | 久久亚洲国产午夜精品理论片 | 国产成人在线视频 | 亚洲国产成人久久一区www妖精 | 视频二区欧美 | 黄色毛片一级 | 国产深夜福利19禁在线播放 | 国产成人精品日本亚洲语音2 | 久久视频这里只精品3国产 久久视频这里只有精品 | 全部免费特黄特色大片视频 | 在线欧美视频免费观看国产 | 欧美 国产 日本 | 男女污污在线观看 | 成人精品一区二区三区中文字幕 | 国产精品久久久久久永久牛牛 | 成人国产三级在线播放 | 玖玖国产精品 | 一级一级一级毛片免费毛片 |