SVN命令詳解

一、將文件checkout到本地目錄php

svn checkout server-path [local-path] [--username=xxxx] [--password=xxxx]服務器

例如:svn checkout svn:192.168.1.1/pro/project project網絡

簡寫:svn codom

二、往版本庫中添加新文件svn

svn add fileurl

例如:svn add test.c(添加test.c)版本控制

svn add *.c(添加當前目錄下的全部.c文件)日誌

三、將改動的文件提交到版本庫server

svn commit -m "LogMessage"  [-N] [--no-unlock] path (若是選擇了保持鎖,就是用-no-unlock開關)ci

例如:svn commit -m "add test file for my test" test.c

簡寫:svn ci

四、加鎖、解鎖

svn lock -m "LockMessage" [--force] PATH

例如:svn lock -m "lock test file" test.c

svn unlock PATH

五、更新到某個版本

svn update -r m path

例如:

svn update若是後面沒有目錄,默認將當前目錄以及子目錄下的全部文件都更新到最新版本

svn update -r 200 test.c 將版本庫中的文件test.c還原到版本200

svn upate test.c (更新,與版本庫同步。若是在提交時提示過時的話,是由於衝突,須要先update,修改文件,而後清除svn resolved,最後再提交commit)

簡寫:svn up

六、查看文件或者目錄狀態

1) svn status path(目錄下的文件和子目錄的狀態,正常狀態不顯示)

『?:不在svn控制中;M:內容被修改;C:發生衝突;A:預訂加入到版本庫;K:被鎖定】

2)svn status -v path(顯示文件和子目錄狀態)

第一列保持相同,第二列顯示工做版本號,第三和第四列顯示最後一次修改的版本號和修改人。

注:svn status、svn diff和svn revert這三條命令在沒有網絡的狀況下也能夠執行的,緣由是svn在本地的.svn目錄中保留了本地版本的原始拷貝。

簡寫:svn st

七、刪除文件

svn delete path -m "delete log"

例如:svn delete svn://192.168.1.1/pro/domain/test.c -m "delete test file"

或者直接svn delete test.c 而後再svn ci -m "delte test file",推薦使用這種

簡寫:svn (del,remove,rm)

八、查看日誌

svn log path

例如:svn log test.c 顯示這個文件的全部修改記錄,及其版本號的變化

九、查看文件詳細信息

svn info path

例如:svn info test.c

十、比較差別

svn diff path (將修改的文件與基礎版本比較)

例如:svn diff test.php

svn diff -r m:n path(對版本m和版本n比較差別)

例如:svn diff -r 200:201 test.c

簡寫:svn di

十一、將兩個版本之間的差別合併到當前文件

svn merge -r m:n path

例如:svn merge -r 200:205 test.c(將版本200與205之間的差別合併到當前文件,可是通常都會產生衝突,須要處理一下)

十二、svn幫助

svn help

svn help ci

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

以上是經常使用命令,下面寫幾個不常常用的

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

1三、版本庫下的文件和目錄列表

svn list path

顯示path目錄下的全部屬於版本庫的文件和目錄

簡寫:svn ls

1四、建立歸入版本控制下的新目錄

svn mkdir

1五、恢復本地修改

svn revert:恢復原始未改變的工做副本文件,

用法: svn revert path

1六、代碼庫url變動

svn switch(sw):更新工做副本至不一樣的URL。

用法:1 svn switch URL [PATH] 更新你的工做副本,映射到一個新的URL,其行爲跟「svn update」很像,也會將服務器上文件與本地文件合併,這是將工做副本對應到同一倉庫中某個分支或者標記的方法。

2 svn switch -relocate FORM TO [PATH...] 改寫工做副本的URL元數據,以反映單純的URL上的改變。當倉庫的URL變更(好比方案名或者主機名成變更),可是工做副本仍舊對映到同一倉庫的同一目錄時使用這個命令更新工做副本與倉庫的對應關係。

1七、解決衝突

svn resolved:移除工做副本的目錄或文件的「衝突」狀態

用法:svn resolved [path]

注意:本命令不會依語法來解決衝突或是移除衝突標記;它只是移除衝突的相關文件,而後讓path能夠在此提交。

1八、輸出指定文件或URL的內容

svn cat 目標[@版本]

svn cat -r PREV filename > filename (PREV是上一版本,也能夠寫具體版本號,這樣輸出結果是能夠提交的)

相關文章
相關標籤/搜索