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

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

系統 1691 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條評論
主站蜘蛛池模板: 亚洲视频在线免费观看 | 91啦丨国产丨| 中文字幕一区二区三区免费视频 | 亚洲一区亚洲二区 | 国产伦精品一区二区三区免费迷 | 玖玖中文| 亚洲成在人线免费视频 | 久久精品免费一区二区三区 | 久久久性视频 | 伊人狼人视频 | 欧美视频一级 | 日本一区二区三区免费在线观看 | 成人性一级视频在线观看 | 久久久久久久国产精品 | 日本视频中文字幕一区二区 | 国产日韩欧美成人 | 久久免费视频7 | 九九这里只有精品视频 | 亚洲欧美国产高清va在线播放 | 欧美日本在线视频 | 黄色高清在线观看 | 国产精品综合一区二区 | 99久久免费视频在线观看 | 亚洲成人手机在线观看 | 国产人成精品综合欧美成人 | 一级一毛片a级毛片 | 免费精品久久久久久中文字幕 | 天天色天天草 | 免费看成人播放毛片 | 国产日韩一区二区三区在线播放 | 久久久精品视频在线观看 | 蕾丝视频在线看片国产 | 大学生久久香蕉国产线看观看 | 夜色资源站www国产在线资源 | 九九热精品视频在线 | 日本午夜免费理论片 | 视频在线观看一区 | 一本清高清dvd日本播放器 | 粗大猛烈进出呻吟声的视频 | 不卡视频免费在线观看 | 日本又黄又爽又色的视频免费 |