svn 代碼如何回滾。
一、改動代碼沒有提交到倉庫
這種情況下,使用svn revert就能取消之前的修改。
svn revert用法如下:
# svn revert [-R] something
其中something可以是(目錄或文件的)相對路徑也可以是絕對路徑。
當something為單個文件時,直接svn revert something就行了;當something為目錄時,需要加上參數-R(Recursive,遞歸),否則只會將something這個目錄的改動。
在這種情況下也可以使用svn update命令來取消對之前的修改,但不建議使用。因為svn update會去連接倉庫服務器,耗費時間。
注意:svn revert本身有固有的危險,因為它的目的是放棄未提交的修改。一旦你選擇了恢復,Subversion沒有方法找回未提交的修改。
二、改動已經被提交(commit)
這種情況下,用svn merge命令來進行回滾。
回滾的操作過程如下:
1、保證我們拿到的是最新代碼:
svn update
2、然后找出要回滾的確切版本號:
svn log [需要回滾的文件名]
可以使用svn diff -r 2932:2922 [需要回滾的文件名],查看兩個版本(2932和2922)之間的差異,加號代表2922版本內容,減號代表2932版本內容。和容易看出版本間差異。

3、將2932版本回滾到版本號2922:
svn merge -r 2932:2922 回滾文件名

為了保險起見,再次確認回滾的結果:
svn diff [回滾文件名] 減號:回滾文件發生改變的行,加號:回滾后的內容

發現正確無誤,提交。
4、提交回滾:
svn commit -m "回滾說明..."

提交后版本變成了2933。
三、總結
1. svn update,svn log,找到最新版本(latest revision)
2. 找到自己想要回滾的版本號(rollbak revision)
3. 用svn merge來回滾: svn merge -r : something