svn 命令行下常用的几个命令

1、将文件checkout到本地目录
 
  svn checkout path(path是服务器上的目录)
   例如:svn checkout svn://192.168.1.1/pro/domain

   简写:svn co


2、往版本库中添加新的文件
 
  svn add file
  例如:svn add test.php(添加test.php)

  svn add *.php(添加当前目录下所有的php文件)


3、将改动的文件提交到版本库
 
  svn commit -m "LogMessage" [-N] [--no-unlock] PATH(如果选择了保持锁,就使用--no-unlock开关)
   例如:svn commit -m "add test file for my test" test.php

   简写:svn ci


4、加锁/解锁
 
  svn lock -m "LockMessage" [--force] PATH
  例如:svn lock -m "lock test file" test.php

  svn unlock PATH


5、更新到某个版本
 
  svn update -r m path
   例如:
   svn update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。
   svn update -r 200 test.php(将版本库中的文件test.php还原到版本200)
   svn update test.php(更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文件,然后清除svn resolved,最后再提交commit)

   简写:svn up


6、查看文件或者目录状态
 
  1)svn status path(目录下的文件和子目录的状态,正常状态不显示)
   【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】
  2)svn status -v path(显示文件和子目录状态)
   第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。
   注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。
   简写:svn st
 
7、删除文件
 
  svn delete path -m "delete test fle"
  例如:svn delete svn://192.168.1.1/pro/domain/test.php -m "delete test file"
  或者直接svn delete test.php 然后再svn ci -m 'delete test file‘,推荐使用这种
  简写:svn (del, remove, rm)
 
8、查看日志
 
  svn log path

  例如:svn log test.php 显示这个文件的所有修改记录,及其版本号的变化


9、查看文件详细信息
 
  svn info path
  例如:svn info test.php
10、比较差异
 
  svn diff path(将修改的文件与基础版本比较)
  例如:svn diff test.php
       svn diff -r m:n path(对版本m和版本n比较差异)
  例如:svn diff -r 200:201 test.php

  简写:svn di


11、将两个版本之间的差异合并到当前文件
 
  svn merge -r m:n path
  例如:svn merge -r 200:205 test.php(将版本200与205之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下)
    
12、SVN 帮助
 
  svn help

  svn help ci


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

 
以上是常用命令,下面写几个不经常用的
 
------------------------------------------------------------------------------
 
13、版本库下的文件和目录列表
 
  svn list path
  显示path目录下的所有属于版本库的文件和目录

  简写:svn ls 


14、创建纳入版本控制下的新目录
 
  svn mkdir: 创建纳入版本控制下的新目录。
  用法: 1、mkdir PATH...
       2、mkdir URL...
 
15、恢复本地修改
 
   svn revert: 恢复原始未改变的工作副本文件 (恢复大部份的本地修改)。revert:
   用法: revert PATH...
   注意: 本子命令不会存取网络,并且会解除冲突的状况。但是它不会恢复
        被删除的目录
 
16、代码库URL变更
 
    svn switch (sw): 更新工作副本至不同的URL。
    用法: 1、switch URL [PATH]
          2、switch --relocate FROM TO [PATH...]
 
          1、更新你的工作副本,映射到一个新的URL,其行为跟“svn update”很像,也会将
             服务器上文件与本地文件合并。这是将工作副本对应到同一仓库中某个分支或者标记的
             方法。
          2、改写工作副本的URL元数据,以反映单纯的URL上的改变。当仓库的根URL变动
             (比如方案名或是主机名称变动),但是工作副本仍旧对映到同一仓库的同一目录时使用
             这个命令更新工作副本与仓库的对应关系。
 
17、解决冲突
 
   svn resolved: 移除工作副本的目录或文件的“冲突”状态。
   用法: resolved PATH...
   注意: 本子命令不会依语法来解决冲突或是移除冲突标记;它只是移除冲突的
   相关文件,然后让 PATH 可以再次提交。
 
18、输出指定文件或URL的内容。
 
  svn cat 目标[@版本]...如果指定了版本,将从指定的版本开始查找。
  svn cat -r PREV filename > filename (PREV 是上一版本,也可以写具体版本号,这样输出结果是可以提交的)
<think>好的,我现在需要帮助用户了解如何使用SVN命令行回退版本并忽略版本一致的问题。首先,我应该回忆一下SVN的相关命令,特别是版本回退的常用方法。 用户提到“回退”和“忽略版本一致”,可能是指将工作副本回退到某个旧版本,同时避免版本冲突或者保持某种一致性。首先,我需要确定SVN回退的几种方式,比如使用svn update指定版本、svn merge进行反向合并,或者直接导出旧版本覆盖。 接下来,回退的具体步骤。常用的方法可能是通过svn update -r来切换到指定版本,但这可能只更新工作副本,之后需要提交,这样会产生一个新的版本。或者使用svn merge来撤销之前的更改,这可能更适合需要保留历史的情况。另外,如果用户希望彻底丢弃之后的更改,可能需要使用svn export然后覆盖工作目录,但这样操作需要谨慎,避免数据丢失。 然后,关于“忽略版本一致”,可能是指处理本地与仓库版本不一致的情况,比如本地有修改但想放弃这些修改,强制回退到某个版本。这时候可能需要使用svn revert来撤销本地更改,再更新到指定版本。或者使用强制解决冲突的方法,比如svn resolve --accept theirs-full等命令。 还需要考虑不同场景下的处理方式,比如是否已经提交了错误的版本,或者只是在本地修改后想要回退。如果已经提交,那么需要回滚到之前的版本并提交,这会影响仓库历史;如果只是本地修改,svn revert就足够了。 可能用户会遇到的问题包括:如何找到需要回退的版本号,这时候可以使用svn log查看提交历史。另外,回退后是否需要提交,以及如何处理之后的版本号递增问题。 需要确保步骤的准确性,比如在使用svn merge进行反向合并时,正确的命令格式是svn merge -c -<版本号>,然后提交更改。同时提醒用户注意备份,避免误操作导致数据丢失。 最后,整理步骤,分点说明不同的回退方法,适用场景,以及如何解决版本一致性问题。确保语言清晰,结构合理,用户能够逐步跟随操作。</think>以下为SVN命令行回退版本及处理版本一致性的分步说明: ### 一、查看提交历史(确定回退目标版本号) ```bash svn log ``` - 输出提交记录,找到需要回退的版本号(如`r123`) --- ### 二、本地未提交修改的回退 1. 丢弃所有本地修改: ```bash svn revert -R . ``` 2. 强制更新到指定版本: ```bash svn update -r 123 ``` --- ### 三、
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值