datediff 函式導致溢位。用於分隔兩個日期/時間例項的日期部分的數字太大

ywxj_001發表於2018-02-22

執行檢查alwayson同步的指令碼:

SELECT  availability_mode_desc ,
        role_desc ,
        replica_server_name ,
        last_redone_time ,
        GETDATE() now ,
        DATEDIFF(ms, last_redone_time, GETDATE()) diffMS
FROM    ( ( sys.availability_groups AS ag
            JOIN sys.availability_replicas AS ar ON ag.group_id = ar.group_id
          )
          JOIN sys.dm_hadr_availability_replica_states AS ar_state ON ar.replica_id = ar_state.replica_id
        )
        JOIN sys.dm_hadr_database_replica_states dr_state ON ag.group_id = dr_state.group_id
                                                             AND dr_state.replica_id = ar_state.replica_id;


報錯:

datediff 函式導致溢位。用於分隔兩個日期/時間例項的日期部分的數字太大。請嘗試使用日期部分精度較低的 datediff。

1、可能是一個日期是空值

2、可能是兩個日期相差太遠


檢查後發現是兩個日期相差太遠。

last_redone_time的時間和GETDATE()的時間相差太遠。

表示有一個庫長時間沒有資料更新,所以last_redone_time的值長時間沒有變。

把那個庫的資料更新一下,同步指令碼正常。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22996654/viewspace-2151146/,如需轉載,請註明出處,否則將追究法律責任。

相關文章