svn 使用记录

linux 使用svn的命令小记:

从服务器将项目检出:

svn checkout  path   其中path为服务器项目地址,一般为url, 比如 https://192.168.1.235/svn/wo/trunk/Develop/Code/

可简写为svn co path


将本地项目导入版本库:

svn import [源路径] [目标版本库路径] -m [日志信息]

增加文件

svn add

删除文件

svn delete

提交修改:

svn commit

显示修改日志:

svn log  -v  ,显示所有日志, 并带修改的文件名

查看版本差异

svn log -r r1:r2  显示两个版本的修改

svn diff -r r1:r2 查两个版本的改动

版本回滚:

svn log 确定版本号

合并回滚 svn merge -r <latest revision>:<last revision> <file>

升级到某个版本

svn up -r


取消对代码的修改:

一种情况改动没有提交:

这种情况下,使用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 
        假设最新版本号是28。 
     2、然后找出要回滚的确切版本号: 
        svn log [something]
        假设根据svn log日志查出要回滚的版本号是25,此处的something可以是文件、目录或整个项目
        如果想要更详细的了解情况,可以使用svn diff -r 28:25 [something]
     3、回滚到版本号25:
           svn merge -r 28:25 something
        为了保险起见,再次确认回滚的结果:
           svn diff [something]
        发现正确无误,提交。
     4、提交回滚:
        svn commit -m "Revert revision from r28 to r25,because of ..." 
        提交后版本变成了29。
     将以上操作总结为三条如下:
     1. svn update,svn log,找到最新版本(latest revision)
     2. 找到自己想要回滚的版本号(rollbak revision)
 
   3. 用svn merge来回滚: svn merge -r : somethin





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值