瀏覽量:79次
一臺服務器重裝系統(tǒng)后,用附加表再配置同步復制的時候出錯:
sql server 無法創(chuàng)建發(fā)布 找不到存儲過程 錯誤 2812
在SQL SERVER 2005中,有數(shù)據(jù)庫DB1,在A服務器上。由于要更換服務器,要把數(shù)據(jù)庫DB1遷移到B服務器上。而DB1是用于同步復制的。粗心的你沒有把同步復制(發(fā)布和訂閱)刪掉附加成功了,原來的程序都能連接上,你以為大功告成。但是,幾天過后,當你想把服務器重新同步復制,以作實時備份時,你發(fā)現(xiàn)自己的倒霉時刻到了。SQL SERVER 2005 像病了一樣,只提示:“找不到存儲過程’’…錯誤:2812”。
如果你的經歷與以下的不完全一致,那么這篇文章可能也值得你參考。
但如果你的經歷恰好一樣,而且你在Google或Baidu上苦尋答案而不覓,那么,這篇文章或者能幫你一把。
如果數(shù)據(jù)庫遷移后,數(shù)據(jù)并沒有更新過。那么你的想法是把這個該死的數(shù)據(jù)庫分離,然后再重新把去掉同步復制的干凈的數(shù)據(jù)庫遷移過來。但是,如果你的新數(shù)據(jù)庫已經投入生產,那么,請參考我的方法:
打開B服務器上的DB1數(shù)據(jù)庫的系統(tǒng)表,你會發(fā)現(xiàn)有12個表在里面。這12個表就是因同步復制而產生的,包括:
表/視圖有記錄復制必需Mspeer_lsnsMspeer_request
Mspeer_response
Mspub_identity_range
Sysarticlecolumns
有是Sysarticles有是Sysarticlesupdates是
syspublications有是Sysreplservers有Sysschemaarticles
是
Syssubscriptions有是systranschemassysextendedarticlesview
是
問題就出現(xiàn)在這里了。這12 個系統(tǒng)表和1個視圖是因同步復制而生的,如果沒有發(fā)生同步復制,他們是不會出現(xiàn)的。我們把mdf和ldf文件直接遷移過來,數(shù)據(jù)庫里面的這些系統(tǒng)表和視圖也隨之而來了。 不能簡單的把這12個系統(tǒng)表和1個視圖刪掉,這樣同樣不行。在經過了長時間的摸索后,我發(fā)現(xiàn)了問題的真正所在。
我們看一下系統(tǒng)表 sysreplservers的內容,有兩列:
SrvnameSrvid舊服務器名稱0終于找到了問題所在了。我們把該表的記錄刪除。
然后隨便發(fā)布一次。
再把該發(fā)布刪除。
至此,該數(shù)據(jù)庫中的陳舊同步復制信息已經去除,數(shù)據(jù)庫重新變得潔凈可愛
[聲明]本網(wǎng)轉載網(wǎng)絡媒體稿件是為了傳播更多的信息,此類稿件不代表本網(wǎng)觀點,本網(wǎng)不承擔此類稿件侵權行為的連帶責任。故此,如果您發(fā)現(xiàn)本網(wǎng)站的內容侵犯了您的版權,請您的相關內容發(fā)至此郵箱【779898168@qq.com】,我們在確認后,會立即刪除,保證您的版權。
官網(wǎng)優(yōu)化
整站優(yōu)化
渠道代理
400-655-5776