日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

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

系統 1979 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條評論
主站蜘蛛池模板: 上饶市| 东乡县| 澳门| 隆林| 英山县| 安化县| 通化县| 阳山县| 全椒县| 沙洋县| 天峻县| 竹北市| 丹阳市| 乌恰县| 五寨县| 汉川市| 武义县| 临漳县| 龙井市| 英德市| 焉耆| 清徐县| 定州市| 资中县| 邢台市| 锡林浩特市| 巴林左旗| 威海市| 靖州| 广东省| 安丘市| 苏州市| 陈巴尔虎旗| 睢宁县| 台前县| 宁海县| 鄂尔多斯市| 徐水县| 绵阳市| 昌图县| 德昌县|