1. 程式人生 > >SQL2005在新建複製 找不到儲存過程 錯誤:2812 的解決方法

SQL2005在新建複製 找不到儲存過程 錯誤:2812 的解決方法

標題: 新建釋出嚮導
------------------------------


SQL Server 無法建立釋出“XXXXX釋出”。


------------------------------
其他資訊:


執行 Transact-SQL 語句或批處理時發生了異常。 (Microsoft.SqlServer.ConnectionInfo)


------------------------------


找不到儲存過程 ''。
找不到儲存過程 ''。
已將資料庫上下文更改為 'db1'。 (Microsoft SQL Server,錯誤: 2812)


有關幫助資訊,請單擊: http://go.microsoft.com/fwlink?ProdName=Microsoft+SQL+Server&ProdVer=10.50.1600&EvtSrc=MSSQLServer&EvtID=2812&LinkId=20476


------------------------------
按鈕:


確定
------------------------------

一臺伺服器重灌系統後,用附加表再配置同步複製的時候出錯:

sql server 無法建立釋出 找不到儲存過程 錯誤 2812

在SQL SERVER 2005中,有資料庫DB1,在A伺服器上。由於要更換伺服器,要把資料庫DB1遷移到B伺服器上。而DB1是用於同步複製的。粗心的你沒有把同步複製(釋出和訂閱)刪掉,就直接把DB1.mdf和DB1_log.ldf兩個檔案到B伺服器上附加。附加成功了,原來的程式都能連線上,你以為大功告成。但是,幾天過後,當你想把伺服器重新同步複製,以作實時備份時,你發現自己的倒黴時刻到了。SQL SERVER 2005 像病了一樣,只提示:“找不到儲存過程’’…錯誤:2812”。

       如果你的經歷與以下的不完全一致,那麼這篇文章可能也值得你參考。

       但如果你的經歷恰好一樣,而且你在Google或Baidu上苦尋答案而不覓,那麼,這篇文章或者能幫你一把。

       如果資料庫遷移後,資料並沒有更新過。那麼你的想法是把這個該死的資料庫分離,然後再重新把去掉同步複製的乾淨的資料庫遷移過來。但是,如果你的新資料庫已經投入生產,那麼,請參考我的方法:

       開啟B伺服器上的DB1資料庫的系統表,你會發現有12個表在裡面。這12個表就是因同步複製而產生的,包括:   

/檢視

有記錄

複製必需

Mspeer_lsns

Mspeer_request

Mspeer_response

Mspub_identity_range

Sysarticlecolumns

Sysarticles

Sysarticlesupdates

syspublications

Sysreplservers

Sysschemaarticles

Syssubscriptions

systranschemas

sysextendedarticlesview

       問題就出現在這裡了。這12 個系統表和1個檢視是因同步複製而生的,如果沒有發生同步複製,他們是不會出現的。我們把mdf和ldf檔案直接遷移過來,資料庫裡面的這些系統表和檢視也隨之而來了。

       不能簡單的把這12個系統表和1個檢視刪掉,這樣同樣不行。在經過了長時間的摸索後,我發現了問題的真正所在。

我們看一下系統表 sysreplservers的內容,有兩列:

Srvname

Srvid

舊伺服器名稱

0

       終於找到了問題所在了。我們把該表的記錄刪除。

       然後隨便釋出一次。

       再把該釋出刪除。

       至此,該資料庫中的陳舊同步複製資訊已經去除,資料庫重新變得潔淨可愛。