1、检出到某一版本:

  svn checkout -r 974  svn://220.231.xx.xx/仓库名

  svn checkout  svn://220.231.xx.xx/仓库名

  svn export svn://220.231.xx.xx/仓库名    //1.不能带导出路径信息 2.导出不带SVN信息的文件

2、检入

  svn import ./  svn://220.231.xx.xx/rda8501_common -m " "  --no-ignore

  一般是在第一次建库时使用,先清理临时文件后,将当前目录下的所有文件导入仓库。

  SVN 会默认忽略掉一些文件,"--no-ignore"参数可以强制全部导入。

3、增加文件并提交

  svn add .         // --force --no-ignore    这两个参数可选

  svn commit ./ -m "svn log"

4、更新

  命令1:svn up     没有指定版本,则将工作副本更新到 HEAD 版本  
  命令2:svn up -r  版本号 更新到-r 选项所指定的版本

5、提交

  svn commit ./

6、版本回退             //svn revert 只能把未提交的本地修改撤销

  svn revert -R 136 ./      //1、-R 表示目录递归。2、后面必须跟路径  表示在哪一级目录执行递归

7、删除文件

  svn del

8、某些文件不能加入版本控制

  vim ~/.subversion/config
  #global-ignores = *.o *.lo *.la *.al .libs *.so *.so.[0-9]* *.a *.pyc *.pyo  #*.rej *~ #*# .#* .*.swp .DS_Store

  注意:去掉#号后要顶行

9、SVN 版本匹配

  svn upgrade    //将一份带有SVN管理的代码,拷贝到一台有更高SVN版本的机器上时,可能会遇到不匹配的情况

10、检查冲突文件

  svn st | grep ^C

11、库地址变更

  svn sw --relocate svn://220.231.xxx.xx/rda8501  svn://radisson.tech/xxx

12、批量删除/增加文件

  svn status | grep ^M | awk '{print $2}' | xargs svn del

  svn status | grep ^M.*\.o$ | awk '{print $2}' | xargs svn del

  先对 M 开头 以 .o 结尾的行进行过滤,提取.o的路径后,进行删除。

  svn status | grep ^? | awk '{print $2}' | xargs svn add

  命令解释:查看哪些文件被修改了,修改的文件送入管道,在版本库中进行删除。

  rm -rf [^r]*

-rwxr--r-- 1 jiangzhaowei jiangzhaowei 451368 56 17:43 rda.IAD*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 10448896 56 17:43 rda.IMB*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 102048 56 17:43 rda.IMD*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 26004 56 17:42 rda.PFI*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 776 56 17:42 rda.PO*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 2034128 56 19:17 rda.PR*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 13192944 56 19:17 rda.PRI*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 75632180 56 19:17 rda.PS*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 1798 56 19:17 rda.SearchResults*
-rwxr--r-- 1 jiangzhaowei jiangzhaowei 45211 56 19:17 rda.WK3*

以下是svn客户端常用命令一览:

svn add [path]

别名:无

描述:添加文件或目录到你的wc,打上新增标记。这些文件会在下一次你提交wc的时候提交到svn服务器。

在提交前,你也可以用svn revert撤销新增的文件。

访问库:否

eg: svn add file.cpp

svn blame Target[@REV]

别名:praise,annotate,ann

描述:显示某个已受控文件的每一行的最后修改版本和作者

访问库:是

eg: svn blame file.cpp

eg: svn blame --xml file.cpp  ##加上xml参数可以以xml格式显示每一行的属性。

svn cat TARGET[@REV]

别名:无

描述:输出指定目标的内容,这里的目标一般是文件。

访问库:是

eg:svn cat file.cpp

eg:svn cat file.cpp -r 2 ##显示版本号为二的file.cpp内容。

eg:svn cat file.cpp --revision HEAD ##显示最新版本的file.cpp内容。

svn changelist CLNAME TARGET...

svn changelist --remove TARGET

别名:cl

描述:可以将wc中的文件从逻辑上分组.

访问库:否

eg:svn cl clName file.cpp file2.cpp file3.cpp  ##将file.cpp等三个文件加入名叫clName的changelist

eg:svn commit --changelist clName -m "ci"  ##将clName下的所有文件提交

svn checkout URL[@REV]... [PATH]

别名:co

描述:检出

访问库:否

eg:svn checkout file:///var/svn/repos/test  file:///var/svn/repos/quiz working-copies

eg:svn checkout -r 2 file:///var/svn/repos/test mine  ##check out 版本号为2的项目

svn cleanup [PATH...]

别名:无

描述:递归的清理WC中过期的锁和未完成的操作。

访问库:否

eg:svn cleanup

svn commit [PATH...]

别名:ci

描述:把你WC的更改提交到仓库

访问库:是

eg:svn commit -m "added howto section." ##默认情况下提交必须提供log message

svn copy SRC[@REV]... DST

别名:cp

描述:copy操作可以从WC到WC;WC到URL;URL到WC;URL到URL。现在SVN只支持同一个仓库内文件的拷贝,不允许跨仓库操作。

访问库:是

eg:svn copy -r 11 file:///var/svn/repos/test/trunk \

file:///var/svn/repos/test/tags/0.6.32-prerelease \

-m "Forgot to tag at rev 11"

##copy命令是创建分支和标记的常用方式。copy到url的操作隐含了提交动作,所以需要提供log messages。

svn delete PATH...

别名:del,remove,rm

描述:删除

访问库:如果PATH是库地址时会,删除WC内的文件不会。

eg:svn del localfile.cpp    ##删除WC里的文件,在下一次提交WC的时候才会真正在仓库里将对应文件删除。

eg: svn del file:///var/svn/repos/test/yourfile  ##删除仓库里的文件

svn diff

别名:di

描述:用来比较并显示修改点。

访问库:

eg:svn diff   ##最常用的方式,用来显示WC基于最近一次更新以后的所有的本地修改点。

eg:svn diff -r 301 bin ## 比较WC和版本301中的bin目录的修改点

eg:svn diff -r 3000:3500 file:///var/svn/repos/myProject/trunk   ##比较库里主干3000版和3500版的差异。

eg:svn diff --summarize --xml http://svn.red-bean.com/repos/test@r2 http://svn.red-bean.com/repos/test  ##--summarize --xml 参数将差异情况以xml文档的方式显示出来。

svn export [-r REV] URL[@PEGREV] [PATH]

svn export [-r REV] PATH1[@PEGREV] [PATH2]

别名:无

描述:导出一个干净的目录树,不包含所有的受控信息。可以选择从URL或WC中导出。

访问库:如果访问的是URL则会。

eg:svn export file:///var/svn/repos my-export   ##导出到my-export目录。

svn help — Help!

别名:?,h

描述:不用解释了

访问库:否。

svn import [PATH] URL

别名:无

描述:导入本地一个目录到库中。但是导入后,本地的目录并不会处于受控状态。

访问库:是。

eg:svn import -m "New import" myproj http://svn.myProject.com/repos/trunk/misc

svn info [TARGET[@REV]...]

别名:无

描述:显示指定WC和URL信息。

访问库:仅当访问的是库路径时。

eg:svn info --xml http://svn.myProject.com/repos/test  ##将信息以xml格式显示。

svn list [TARGET[@REV]...]

别名:ls

描述:显示目标下的文件和目录列表。

访问库:如果访问的是库地址就会。

eg:svn list --verbose file:///var/svn/repos   ##--verbose参数表示显示详细信息。

svn lock TARGET...

别名:无

描述:对目标获得修改锁。如果目标已被其他用户锁定,则会抛出警告信息。用--force参数强制从其他用户那里获得锁。

访问库:是

eg:svn lock --force tree.jpg

svn log [PATH]

svn log URL[@REV] [PATH...]

别名:无

描述:从库中显示log消息。log消息代码 A :added  D:deleted  M:modified  R:replaced

访问库:是

eg:svn log -v http://svn.myProject.com/repos/test/ foo.c bar.c   ##详细显示指定URL的库中foo.c和bar.c所有版本的log信息。

eg:svn log -r 14:15    ##显示当前WC的14和15版本log信息。

eg:##如果版本号不连续,只能采用如下方式。

$ svn log -r 14 > mylog

$ svn log -r 19 >> mylog

$ svn log -r 27 >> mylog

svn merge sourceURL1[@N] sourceURL2[@M] [WCPATH]

svn merge sourceWCPATH1@N sourceWCPATH2@M [WCPATH]

svn merge [[-c M]... | [-r N:M]...] [SOURCE[@REV] [WCPATH]]

别名:无

描述:合并两个受控源的不同之处,存放到一个WC里。

访问库:只有当访问库地址时。

eg:svn merge --reintegrate http://svn.example.com/repos/calc/branches/my-calc-branch  ##合并分支上的改变项到WC,往往用于分支合并到主干。

eg:svn merge -r 156:157 http://svn.example.com/repos/calc/branches/my-calc-branch   ##将制定URL版本156到157的所有更新合并到WC。

svn mkdir PATH...

svn mkdir URL...

别名:无

描述:在WC或库路径创建目录

访问库:只有当访问库地址时。

eg:svn mkdir newdir

svn move SRC... DST

别名:mv, rename, ren

描述:等同于svn copy命令跟个svn delete命令。WC到URL的重命名是不被允许的。

访问库:只有当访问库地址时。

eg:svn move foo.c bar.c  ##将foo.c改名成bar.c。

svn propdel PROPNAME [PATH...]

svn propdel PROPNAME --revprop -r REV [TARGET]

别名:pdel, pd

描述:从受控文件,目录等删除属性。第二种是删除某个指定版本上的附加属性。

访问库:只有当访问库地址时。

eg:svn propdel svn:mime-type someFile    ##从someFile上移除svn:mime-type这个属性。

svn propedit PROPNAME TARGET...

svn propedit PROPNAME --revprop -r REV [TARGET]

别名:pedit, pe

描述:编辑属性

访问库:只有当访问库地址时。

eg:svn propedit svn:keywords  file.c  ##修改file.c上的svn:keywords属性。

svn propget PROPNAME [TARGET[@REV]...]

svn propget PROPNAME --revprop -r REV [URL]

别名:pget,pg

描述:从文件,目录或版本取得指定属性的值。

访问库:只有当访问库地址时。

eg:svn propget svn:keywords file.c   ##从file.c中取得svn:keywords属性的值

svn proplist [TARGET[@REV]...]

svn proplist --revprop -r REV [TARGET]

别名:plist, pl

描述:列出文件、目录或版本上的所有附加属性

访问库:只有当访问库地址时。

eg:svn proplist --verbose file.c

svn propset PROPNAME [PROPVAL | -F VALFILE] PATH...

svn propset PROPNAME --revprop -r REV [PROPVAL | -F VALFILE] [TARGET]

别名:pset,ps

描述:给文件、目录或版本附加属性并赋值

访问库:只有当访问库地址时。

eg:svn propset svn:mime-type image/jpeg file.jpg   ##给file.jpg附加属性svn:mime-type 其值为image/jpeg

eg:svn propset --revprop -r 25 svn:log "Journaled about trip to New York."

##给版本25补上log message

eg:svn propset svn:ignore '.classpath' .

##在本地忽略掉.classpath文件

svn resolve PATH...

别名:无

描述:将冲突的文件标记为已解决,并且删掉冲突产生的临时文件。注意这个命令并不是能把冲突解决,解决冲突还是得靠人工。

访问库:否

eg:svn resolve --accept mine-full foo.c   ##1.5版本后,加上--accept参数,尝试自动处理冲突。

svn resolved PATH...

别名:无

描述:已过时,被resolve --accept取代。去除冲突的状态和冲突临时文件。

访问库:否

svn revert PATH...

别名:无

描述:还原WC中所有的本地更改。

访问库:否

eg:svn revert --depth=infinity .   ##将整个目录所有文件还原

svn status [PATH...]

别名:stat, st

描述:输出WC中文件和目录的状态。如果WC提交,这些状态就会同步到库里。

一般状态有         ' '  没有修改

'A'  新增

'D'  删除

'M'  修改

'R'  替代

'C'  冲突

'I'  忽略

'?'  未受控

'!'  丢失,一般是将受控文件直接删除导致

访问库:加上--show-updates参数时会

eg:svn status wc

svn switch URL[@PEGREV] [PATH]

svn switch --relocate FROM TO [PATH...]

别名:sw

描述:将WC转向一个其他的库地址同步

访问库:是

eg:svn sw http://svn.myProject.com/repos/trunk/vendors .  ##将当前WC切换到另一个URL

svn unlock TARGET...

别名:无

描述:解锁

访问库:是

eg:svn unlock somefile

svn update [PATH...]

别名:up

描述:更新WC,更新反馈有如下几种分类。

A  新增

B  锁破坏

D  删除

U  更新

C  冲突

G  合并

E  存在的

访问库:是

eg:svn up -r22   ##更新到一个指定版本

ps:如何去除SVN中保存的用户授权密码

在Subversion安装目录下找到auth/svn.simple目录,将下面的文件删除即可。

如果在乌龟中,可以setting->saved data->Authentication Data   点 clear 即可。

SVN 命令使用-***的更多相关文章

  1. [Linux & SVN] SVN介绍及Linux下SVN命令收录

    1. SVN是什么? SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS.CVS,它采用了分支管理系统,它的设计目标就是取代CVS.互联网上很多版本控制服务已从CVS迁移 ...

  2. 常用SVN命令

    SVN命令 svn co  svn://10.144.156.41/branches/webroot_2015_03_03_gift 表示check远程目录到当前目录下,co命令只能check目录,如 ...

  3. Linux SVN 命令详解(zz)

    Linux下常用SVN命令 2012-04-02 11:46:00 标签:服务器 目录 Linux checkout linux系统 1.将文件checkout到本地目录 svn checkout p ...

  4. Mac SVN 命令行

    Mac自带了SVN命令行,如我的升级到10.10(OSX yosemite)后命令行版本为1.7.10 以下是一些常用命令 1.将文件checkout到本地目录 svn checkout path(p ...

  5. linux下svn命令使用大全

    最近经常使用svn进行代码管理,这些命令老是记不住,得经常上网查,终于找了一个linux下svn命令使用大全:1.将文件checkout到本地目录 svn checkout path(path是服务器 ...

  6. 日常开发使用SVN命令

    现在把我日常开发中用到的svn命令总结出来,做个备忘,其实真正用到也就那几个. 如果遇到参数不知道使用或其它困难请使用:svn --help 得到帮助 1)检出: svn co svn地址 本地路径 ...

  7. mac 终端 svn 命令(转)

    mac 终端 svn 命令 1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录)   例如:svn checkout svn://192.168.1.1 ...

  8. svn命令行修改已提交的版本备注

    svn命令行修改已提交的版本备注 参考文章: stackoverflow.com/questions/304383/how-do-i-edit-a-log-message-that-i-already ...

  9. Linux下svn命令详解

    本文主要是说明linux下svn命令的使用方法,同时记录自己在使用中遇到的一些疑惑. 1.Linux命令行下将文件checkout到本地目录 svn checkout url(url是服务器上的目录) ...

  10. linux下svn命令大全

    linux下svn命令大全 1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录) 例如:svn checkout svn://192.168.1.1/p ...

随机推荐

  1. 如何用hexo+github搭建个人博客

    搭建环境 1.安装 Node.js: https://nodejs.org/en/ windows下点击链接,下载安装即可;Linux下更加简单,在终端下输入sudo apt-get install ...

  2. ubuntu 忘记root密码

    Ubuntu14.04系统中,因为误操作导致管理员密码丢失或无效,并且忘记root密码,此时无法进行任何root/sudo权限操作.可以通过GRUB重新设置root密码,并恢复管理员账户到正常状态. ...

  3. Kafka高可用环境搭建

    Apache Kafka是分布式发布-订阅消息系统,在 kafka官网上对 kafka 的定义:一个分布式发布-订阅消息传递系统. 它最初由LinkedIn公司开发,Linkedin于2010年贡献给 ...

  4. inline-block和同级的text-align问题

    https://www.cnblogs.com/qjqcs/p/5551640.html margin:0 auto:是设置块标签在父级中居中对齐,是一种对齐方式.所以对于display:inline ...

  5. linux命令:mv命令

    mv命令是move的缩写,可以用来移动文件或者将文件改名(move (rename) files),是Linux系统下常用的命令,经常用来备份文件或者目录. 1.命令格式: mv [选项] 源文件或目 ...

  6. JMeter报错 ERROR o.a.j.t.JMeterThread: Test failed!

    第一次用JMeter,然后跟着教程走,发现进行测试的时候直接报错 显示如下 反复测试依然报错,网上搜索也没什么结果,自己测试了一下才发现问题. 左边创建了CSV DATA 但是并没有进行设置  导致报 ...

  7. Oracle大数据表的分表处理

    1.首先给大数据表创建rownum序列号 --增加序列号字段 alter table TEST add xlh number; --填充序列号 update TEST set xlh = rownum ...

  8. cms实例笔记(二)

    栏目分级: 一.首页 二.解决方案 (栏目) 1.栏目模型 名称: 新闻: 封面模板:cover.html (没有子栏目模型不会用到) 列表页模板:list.html 2.文档模型 名称:新闻 模板: ...

  9. 19条ANDROID平台设计规范平台设计规范

    1.尺寸以及分辨率: Android的界面尺寸比较流行的有:480*800.720*1280.1080*1920,我们在做设计图的 时候建议是以 480*800的尺寸为标准: 2.界面基本组成元素: ...

  10. 51nod 1449 贪心

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1449 1449 砝码称重 题目来源: CodeForces 基准时间限制 ...