SVN命令使用詳解

1、檢出
svn??co??http://路徑(目錄或文件的全路徑) [本地目錄全路徑]?

?--username 用戶名 --password 密碼svn??co??svn://路徑(目錄或文件的全路徑) [本地目錄全路徑]??--username 用戶名 --password 密碼
svn??checkout??http://路徑(目錄或文件的全路徑) [本地目錄全路徑] --username 用戶名
svn??checkout??svn://路徑(目錄或文件的全路徑) [本地目錄全路徑]??--username 用戶名
注:如果不帶--password 參數傳輸密碼的話,會提示輸入密碼,建議不要用明文的--password 選項。
  其中 username 與 password前是兩個短線,不是一個。
  不指定本地目錄全路徑,則檢出到當前目錄下。
例子:
svn co svn://localhost/測試工具?/home/testtools?--username?wzhnsc
svn co http://localhost/test/testapp?--username?wzhnsc
svn checkout svn://localhost/測試工具?/home/testtools?--username?wzhnsc
svn?checkouthttp://localhost/test/testapp?--username?wzhnsc

2導出(導出一個干凈的不帶.svn文件夾的目錄樹)
svn??export??[-r 版本號]??http://路徑(目錄或文件的全路徑) [本地目錄全路徑] --username 用戶名
svn??export??[-r 版本號]??svn://路徑(目錄或文件的全路徑) [本地目錄全路徑] --username 用戶名
svn??export??本地檢出的(即帶有.svn文件夾的)目錄全路徑??要導出的本地目錄全路徑
注:第一種從版本庫導出干凈工作目錄樹的形式是指定URL,
   如果指定了修訂版本號,會導出相應的版本,
   如果沒有指定修訂版本,則會導出最新的,導出到指定位置。
   如果省略?本地目錄全路徑,URL的最后一部分會作為本地目錄的名字。
  第二種形式是指定 本地檢出的目錄全路徑 到 要導出的本地目錄全路徑,所有的本地修改將會保留,
   但是不在版本控制下(即沒提交的新文件,因為.svn文件夾里沒有與之相關的信息記錄)的文件不會拷貝。
例子:
svn?export
?svn://localhost/測試工具?/home/testtools?--username?wzhnsc
svn?export
?svn://localhost/test/testapp?--username?wzhnsc
svn?export
?/home/testapp?/home/testtools

3、添加新文件?
svn add 文件名
注:告訴SVN服務器要添加文件了,還要用svn commint -m真實的上傳上去!
例子:
svn add?test.php?<-?添加test.php?
svn commit -m?“添加我的測試用test.php“ test.php
svn add?*.php?<-?添加當前目錄下所有的php文件
svn commit -m?“添加我的測試用全部php文件“ *.php

4、提交
svn commit -m “提交備注信息文本“ [-N] [--no-unlock] 文件名
svn ci -m “提交備注信息文本“ [-N] [--no-unlock] 文件名
必須帶上-m參數,參數可以為空,但是必須寫上-m
例子:
svn commit -m?“提交當前目錄下的全部在版本控制下的文件“ *?<-?注意這個*表示全部文件
svn commit -m?“提交我的測試用test.php“ test.php
svn commit -m?“提交我的測試用test.php“?-N --no-unlock?test.php?<-?保持鎖就用–no-unlock開關
svn ci -m?“提交當前目錄下的全部在版本控制下的文件“ *?<-?注意這個*表示全部文件
svn ci -m?“提交我的測試用test.php“ test.php
svn ci -m?“提交我的測試用test.php“?-N --no-unlock?test.php?<-?保持鎖就用–no-unlock開關

5、更新文件
svn update
svn update -r 修正版本 文件名
svn update 文件名
例子:
svn update?<- 后面沒有目錄,默認將當前目錄以及子目錄下的所有文件都更新到最新版本
svn update -r?200 test.cpp?<-?將版本庫中的文件 test.cpp 還原到修正版本(revision)200
svn update?test.php?<-?更新與版本庫同步。
            提交的時候提示過期沖突,需要先 update 修改文件,
            然后清除svn resolved,最后再提交commit。


6、刪除文件
svn delete svn://路徑(目錄或文件的全路徑) -m “刪除備注信息文本”
推薦如下操作:
svn delete 文件名?
svn ci -m “刪除備注信息文本”
例子:
svn delete svn://localhost/testapp/test.php?-m?“刪除測試文件test.php”
推薦如下操作:
svn delete?test.php?
svn ci -m?“刪除測試文件test.php”

7、加鎖/解鎖?
svn lock -m “加鎖備注信息文本“ [--force] 文件名?
svn unlock 文件名
例子:
svn lock -m?“鎖信測試用test.php文件“ test.php?
svn unlock?test.php

8、比較差異?
svn diff 文件名?
svn diff -r 修正版本號m:修正版本號n 文件名
例子:
svn diff?test.php<-?將修改的文件與基礎版本比較
svn diff -r?200:201 test.php<-?對 修正版本號200 和 修正版本號201 比較差異

9、查看文件或者目錄狀態
svn st?目錄路徑/名
svn status 目錄路徑/名<-?目錄下的文件和子目錄的狀態,正常狀態不顯示?
             【?:不在svn的控制中; ?M:內容被修改;C:發生沖突;
              A:預定加入到版本庫;K:被鎖定】?
svn ?-v 目錄路徑/名
svn status -v 目錄路徑/名<-?顯示文件和子目錄狀態
              【第一列保持相同,第二列顯示工作版本號,
               第三和第四列顯示最后一次修改的版本號和修改人】?
注:svn status、svn diff和 svn revert這三條命令在沒有網絡的情況下也可以執行的,
  原因是svn在本地的.svn中保留了本地版本的原始拷貝。?

10、查看日志
svn log 文件名
例子:
svn log?test.php<-?顯示這個文件的所有修改記錄,及其版本號的變化?

11、查看文件詳細信息
svn info 文件名
例子:
svn info?test.php

12、SVN 幫助
svn help?<-?全部功能選項
svn help ci?<- 具體功能的說明

13、查看版本庫下的文件和目錄列表?
svn list svn://路徑(目錄或文件的全路徑)
svn ls svn://路徑(目錄或文件的全路徑)
例子:
svn list svn://localhost/test
svn ls svn://localhost/test?<-?顯示svn://localhost/test目錄下的所有屬于版本庫的文件和目錄?

14、創建納入版本控制下的新目錄
svn mkdir 目錄名
svn mkdir -m "新增目錄備注文本" http://目錄全路徑
例子:
svn mkdir?newdir
svn mkdir -m?"Making a new dir."?svn://localhost/test/newdir?
注:添加完子目錄后,一定要回到根目錄更新一下,不然在該目錄下提交文件會提示“提交失敗”
svn update
注:如果手工在checkout出來的目錄里創建了一個新文件夾newsubdir,
  再用svn mkdir?newsubdir命令后,SVN會提示:
  svn: 嘗試用 “svn add”或 “svn add --non-recursive”代替?
  svn: 無法創建目錄“hello”: 文件已經存在
  此時,用如下命令解決:
  svn add --non-recursive?newsubdir
  在進入這個newsubdir文件夾,用ls -a查看它下面的全部目錄與文件,會發現多了:.svn目錄
  再用 svn mkdir -m "添hello功能模塊文件" svn://localhost/test/newdir/newsubdir 命令,
  SVN提示:
  svn: File already exists: filesystem '/data/svnroot/test/db', transaction '4541-1',
  path '/newdir/newsubdir '

15、恢復本地修改?
svn revert [--recursive] 文件名
注意: 本子命令不會存取網絡,并且會解除沖突的狀況。但是它不會恢復被刪除的目錄。
例子:
svn revert?foo.c?<-?丟棄對一個文件的修改
svn revert --recursive?.?<-恢復一整個目錄的文件,. 為當前目錄?

16、把工作拷貝更新到別的URL?
svn switch http://目錄全路徑 本地目錄全路徑
例子:
svn switch http://localhost/test/456 .?<- (原為123的分支)當前所在目錄分支到localhost/test/456

17、解決沖突?
svn resolved [本地目錄全路徑]
例子:
$ svn update
C foo.c
Updated to revision 31.
如果你在更新時得到沖突,你的工作拷貝會產生三個新的文件:
$ ls
foo.c
foo.c.mine
foo.c.r30
foo.c.r31
當你解決了foo.c的沖突,并且準備提交,運行svn resolved讓你的工作拷貝知道你已經完成了所有事情。
你可以僅僅刪除沖突的文件并且提交,但是svn resolved除了刪除沖突文件,還修正了一些記錄在工作拷貝管理區域的記錄數據,所以我們推薦你使用這個命令。

18、不checkout而查看輸出特定文件或URL的內容?
svn cat http://文件全路徑
例子:
svn cat http://localhost/test/readme.txt

19、新建一個分支copy

svn copy?branchA branchB??-m "make B branch" // 從branchA拷貝出一個新分支branchB

20、合并內容到分支merge

svn merge?branchA branchB??// 把對branchA的修改合并到分支branchB

轉載于:https://www.cnblogs.com/gide/p/4626575.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/257079.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/257079.shtml
英文地址,請注明出處:http://en.pswp.cn/news/257079.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

服務器排障 之 nginx 499 錯誤的解決

問題描述: Nginx 服務器大量499報錯 220.181.165.136 - - [18/May/2015:10:31:02 0800] "POST /v1/jobsHTTP/1.1" 499 0 "" "bdHttpRequest/1.0.0"115.239.212.7 - - [18/May/2015:10:31:03 0800] "GET /v1/job/643309e3-dc73-4…

二叉查找樹的先序遍歷,中序遍歷,后序遍歷

1、有一個二叉查找樹,存儲者字符A,B,C,D,E,F,G,H,下面哪個結果是后序樹遍歷結果 A. ADBCEGFH B. BCAGEHFD C. BCAEFDHG D. BDACEFHG 我的結題思路是將每個答案按照后序的遍歷方法把二叉樹存儲數據的結構還原,看是否滿足二叉樹的性質。 二叉樹的性…

學習筆記(13):Python網絡編程并發編程-解決粘包問題-終極版本

立即學習:https://edu.csdn.net/course/play/24458/296244?utm_sourceblogtoedu 粘包現象解決(終極版) 1.簡單版的問題所在 1)報頭信息不一定只是包含著命令執行結果的字節數長度,在文件傳輸的時候也可能包含文件名等&#xff0c…

C#多態

C#多態 多態性(C# 編程指南)轉自MSDN通過繼承,一個類可以用作多種類型:可以用作它自己的類型、任何基類型,或者在實現接口時用作任何接口類型。這稱為多態性。C# 中的每種類型都是多態的。類型可用作它們自己的類型或用…

Ubuntu 14.04.02 安裝openvswitch-2.3.1

Open vSwitch安裝 安裝好操作系統 # lsb_release -a LSB Version: core-2.0-amd64:core-2.0-noarch:core-3.0-amd64:core-3.0-noarch:core-3.1-amd64:core-3.1-noarch:core-3.2-amd64:core-3.2-noarch:core-4.0-amd64:core-4.0-noarch:core-4.1-amd64:core-4.1-noarch:security…

struts-上傳

一、創建項目項目名稱:demoupload二、添加jar包commons-fileupload-1.2.2.jarcommons-io-2.0.1.jarcommons-lang3-3.1.jarfreemarker-2.3.19.jarjavassist-3.11.0.GA.jarognl-3.0.5.jarstruts2-core-2.3.4.1.jarxwork-core-2.3.4.1.jar三、在web.xml文件中配置過濾器…

將數組作為參數,調用該函數時候給的是數組地址還是整個數組

1、在實際的應用中,數組經常作為函數參數,將數組中的數據傳遞到另外一個函數中,一般來說,傳遞可以采用兩種方法: 1>、數組元素作為函數的實參時,用法跟普通變量作參數相同,將數組元素的值傳遞…

C#項目中常用到的設計模式

C#項目中常用到的設計模式 1. 引言 一個項目的通常都是從Demo開始,不斷為項目添加新的功能以及重構,也許剛開始的時候代碼顯得非常凌亂,毫無設計可言。但是隨著項目的迭代,往往需要將很多相同功能的代碼抽取出來,這也是…

學習筆記(14):Python網絡編程并發編程-文件傳輸功能實現

立即學習:https://edu.csdn.net/course/play/24458/296245?utm_sourceblogtoedu 1.課程目的: 實現客戶端輸入下載文件的命令,然后將命令發送給服務端,服務端再執行下載文件的命令,最后將執行下載文件命令后的結果返回給客戶端&a…

NFS精簡版配置方法

此實驗的前提是防火墻需關閉。 1.關閉iptables /etc/init.d/iptables stop /etc/init.d/iptables status 2.關閉selinux setenforce 0 getenforce Permissive ---出現這個單詞即代表selinux臨時關閉,如需永久關閉則需修改/etc/sysconfig/selinux配置文件 …

Serializable接口中serialVersionUID字段的作用

序列化運行時使用一個稱為 serialVersionUID 的版本號與每個可序列化類相關聯,該序列號在反序列化過程中用于驗證序列化對象的發送者和接收者是否為該對象加載了與序列化兼容的類。 如果接收者加載的該對象的類的 serialVersionUID 與對應的發送者的類的版本號不同&…

重新認知指針

1、把指針指向的變量的數據類型稱為指針的數據類型;而任何一個指針變量本身數據值的類型都是unsigned long int 2.、指針變量名前的符號“*”表示的是指向運算。 3、不要認為“ *p" 是指針變量,指針變量是p而不是*p 4、

分布式數據庫 HBase

原文地址:http://www.oschina.net/p/hbase/ HBase 概念 HBase – Hadoop Database,是一個高可靠性、高性能、面向列、可伸縮的分布式存儲系統,利用HBase技術可在廉價PC Server上搭建起大規模結構化存儲集群。 HBase是Google Bigtable的開源實…

學習筆記(15):Python網絡編程并發編程-進程理論

立即學習:https://edu.csdn.net/course/play/24458/296423?utm_sourceblogtoedu 1.進程:正在運行的一個過程或者一個任務; 2.進程與程序的區別:程序是一堆代碼,程序運行起來就是進程了,一個程序運行兩次,算…

【翻譯】Designing Websites for iPhone X

讓網站適配 iphone X 英文原文地址:https://webkit.org/blog/7929/...本文原文地址:https://github.com/cnsnake11/... The section below about safe area insets was updated on Oct 31, 2017 to reflect changes in the iOS 11.2 beta. 以下關于safe …

指針作為函數參數引用數組的任意元素

void swap(int *a,int*b) {*a*a^*b;*b*a^*b;*a*a^*b; } swap(data[j],data[j1]); int data[10]{13,55,48,13,62,45,754,0,10};以上是我遇到的問題,我覺得調用這個swap函數是不能這樣直接把數組的某個元素直接丟給swap數據 在程序中參加數據處理的量不是指…

使用 Log4Net 記錄日志

第一步:下載Log4Net 下載地址:http://logging.apache.org/log4net/download_log4net.cgi 把下載的 log4net-1.2.11-bin-newkey解壓后,如下圖所示: 雙擊bin文件夾 雙擊net文件夾,選擇針對.NET FramerWork的不同版本 找…

Xcode常用快捷鍵

1. 文件CMD N: 新文件CMD SHIFT N: 新項目CMD O: 打開CMD S: 保存CMDOPtS:保存所有文件CMD SHIFT S: 另存為CMD W: 關閉窗口CMD Q :退出XcodeCMD SHIFT W: 關閉文件2. 編輯CMD [: 左縮進CMD ]: 右縮進CMDshiftF:項目中查找CMDG:查找下一個CMDshiftG:查…

學習筆記(16):Python網絡編程并發編程-開啟子進程的兩種方式

立即學習:https://edu.csdn.net/course/play/24458/296424?utm_sourceblogtoedu #方式一:使用python內置模塊multiprocessing下的process類 from multiprocessing import Process import time#定義進程函數 def task(name):print(%s is running!%name)t…

ElasticSearch的API python調用

os json datetime datetime django.http HttpResponse reelasticsearch Elasticsearches Elasticsearch([])res8 es.search({:{:{:{::}}}} ) statistic():():hit res8[][]:a (%hit %hit[])a re.split(a);arow a:id row[] row[]idHttpResponse(a)轉載于:https://blog.51cto…