新公司用SVN来管理代码,而且公司自己搭建了SVN服务器,所以要学习下SVN的相关命令、服务器搭建等技能知识。上家公司是用Git管理代码,而且代码托管在git@oschina上,自然不用操心Git服务器的问题,只要熟悉Git常用的命令就可以了。下面来学习下SVN(客户端)的基本命令,简单来说就是:

1,如何从远程仓库拉(检出)代码、如何拉取(获取)远程代码的更新

2,如何检查本地仓库状态

3,如何添加新文件到代码库

4,如何提交文件修改到代码库

5,如何查看修改日志

6,如何对比文件

7,如何解决冲突

8,如何回滚更改

如何...,暂时只想到上面的需求,以后想到了或遇到了再完善。

1,先找个SVN服务器来做实验

其实可以自己搭建一个svn服务器,不过今天暂时先不搭建,先来学svn的基本命令。那么我们先找一个免费的svn服务器,大家可以百度,我找的是这个:淘宝Code

然后可以根据提示先建一个远程的项目,就相当于在SVN服务器上新建一个项目。这个和Git其实差不太多。

2,将远程仓库的代码检出到本地

这一步其实和git也差不多,git是clone到本地。

3,检查本地代码状态

在项目目录下面执行:svn status,这个和git status也差不多,只不过,如果没有更改的话,svn好像什么信息也不显示。

4,添加新文件到本地代码库

在learn-svn/trunk下

可以看到svn会提示有新文件被添加,svn add test.note就可以添加文件到版本库,但svn不支持像git add .这样的操作。然后再检查下状态:

可以看到文件被添加到本地版本库,这里其实相当于git commit,那么如何提交到远程仓库呢?

5,提交代码到远程仓库

svn commit -m "add file"就可以提交到远程仓库,这和git的git push不一样。

6,查看日志

svn log可以查看提交日志

svn log -r 3 -v查看版本3的详细日志

感觉这个和git log不太一样,git log提供的信息好像比较多。

7,比较差异

svn diff可以比较代码差异,在修改未提交到远程代码库时可以比较差异,命令:svn diff trunk 远程仓库地址,这个和git差不多。

8,更新本地代码库和解决冲突

当a和b同时修改了一个文件,并且a的修改被提交到远程代码库,而b在未更新本地代码库的时候却尝试提交代码到远程代码库,这时是不可能提交成功的。这时b需要先更新本地代码库:

svn update,这和git fetch/pull不同,但其实实质应该是差不多的,都是先获取远程代码,然后将本地代码与远程代码合并。如果有冲突,则会提示不能合并,解决冲突后才能合并。

svn解决冲突的操作要比git要复杂一些,有时间再仔细看下。

今天先到这儿,后续会接着学习如何在本地创建仓库、新建分支、删除分支、合并分支等与分支相关的操作,以及如何搭建SVN服务器。

版本管理工具SVN学习(一):简单的SVN命令,兼对比Git的更多相关文章

  1. SVN学习之windows下svn的安装

    svn是apache的一个开源项目,全称为subversion.是一个基于版本的项目管理软件,一般在多人开发的项目中使用,目前svn已经替代了原来的cvs.大多数情况下,svn服务安装在linux服务 ...

  2. SVN学习(二)——SVN 提交、更新、解决冲突等操作步骤

    1. 纳入版本控制 ①新建文件abc.txt ②在文件上点右键 ③添加后文件图标发生变化 2. 提交 ①使用TortoiseSVN可以提交具体某一个文件,或某一个目录下的所有改变.方法就是在想要提交的 ...

  3. SVN学习(一)——SVN 检出文件步骤、图标显示及含义

    May, I come... 1. 创建一个目录用来存放检出得到的文件,例如MyCRM 2. 直接进入目录MyCRM,点右键 3. 可以看到检出得到的文件 此时文件图标上没有任何标识.可能你会想到通过 ...

  4. python学习:简单的wc命令实现

    #!/usr/bin/python   import sys import os   try:     fn = sys.argv[1] except IndexError:     print &q ...

  5. Github学习进阶-初露锋芒,通过命令行将本地git仓库推送到Github上面的仓库

    前提: 1. 需要安装git 客户端.  能打开 git  bash 命令行窗口. 2. 生成了ssh 秘钥,并添加到了Github上面. 一.在Github上面建立一个git仓库. 点击 + 号,在 ...

  6. 版本管理工具 —— SVN

    想想我们在开发过程中是不是会遇到这样的情况: 今天写了很长的一段代码,觉得不合理,然后删了,第二天突然发现昨天的那段代码才是正确的,那怎么办,也无法撤销删除的代码? 还有团队中多人共同开发一个项目,如 ...

  7. SVN学习——简单入门之创建仓库、导入、检出(一)

    从刚刚参加工作就开始使用svn,清晰的记得那年师姐比较生气的来找我:“你怎么又不更新就提交代码了,把我写的都给覆盖掉了”,哈哈~ 虽然一直在用svn,不过在日常工作中主要用到的是简单的操作,而且大多数 ...

  8. SVN版本控制工具使用学习

    SVN版本控制工具使用学习 Subversion是优秀的版本控制工具. 1.下载和搭建SVN服务器 http://subversion.apache.org/packages.html 类型有5种,推 ...

  9. 在Eclipse中使用版本管理工具SVN

    近日工程中,逐渐感觉到原来复制粘贴代码的笨重,突然想起以前有人和我说起过Git和SVN之类的版本管理工具.由于平时主要是写Java代码,所以能够在Eclipse中使用SVN工具进行版本管理就可以说是很 ...

随机推荐

  1. web与request

          request --> 封装了客户端所有的请求数据!       请求行       请求头       空行       请求体(GET没体) 回忆一下http协议!请求协议中的数 ...

  2. pygame加载中文名mp3文件出现error

    好一阵子没有写东西了,最近几天在做一个基于Python pygame的音乐播放器,本来想做完了,再来发篇文章的,可越做越深,框架大致出来了,考虑周期比较长,也可能是我个人问题,做得比较慢,最近.下面来 ...

  3. Appium 解决锁屏截屏问题(java篇)

    今天有个小伙伴问我,怎么把锁屏进行解锁操作?   A.思路在初始化driver后,加入等待判断是否有锁屏(元素)(记得要加入等待) B.如果有就进行解锁,就一般的输入数字密码然后进行解锁(当然了你要知 ...

  4. WebService返回数据前台获取并处理JSON的相关问题

    起因: 记录这个问题的起因是一次解答网友的问题,当初自己初次接触webservice时也遇到过,但在写答案时,并没有很深的印象,只是知道webservice在后台返回值的时候,那里是有个坑的.网友问的 ...

  5. centos5.11架设svn(svn系列 架设服务器 知识一总结)

    ♣svn是什么? ♣安装    --yum安装    --创建svn版本库目录    --创建版本库    --进入conf目录进行配置(该svn版本库配置文件)    --启动svn版本库    - ...

  6. 动态代理的两种实现方式(JDK/Cglib)

    =========================================== 原文链接: 动态代理的两种实现方式(JDK/Cglib) 转载请注明出处! ================== ...

  7. MongoDB基础教程系列--第四篇 MongoDB 查询文档

    查询文档 查询文档可以用 find() 方法查询全部文档,可以用 findOne() 查询第一个文档,当然还可以根据 条件操作符 和 $type操作符 查询满足条件的文档. find() 和 find ...

  8. 学习HTML5的第二周

    ---恢复内容开始--- 这是我学习H5的第二周,在本周,我独立完成了一个网站的首页和一个二级页,虽然在做网页的时候我遇到了许多问题,但我自己想办法解决了其中的大部分,只留下了一小部分没有头绪的问题等 ...

  9. Entity Framework Code First在Oracle下的伪实现

    为什么要说是伪实现,因为还做不到类似MsSql中那样完全的功能.Oralce中的数据库还是要我们自己手动去创建的.这里,我们舍掉了Model First中的EDMX文件,自己在代码里面写模型与映射关系 ...

  10. js alert(“”)弹框 自定义样式

    首先用css渲染一个样式 #msg{ height: 2rem; text-align: center; position: fixed; top: 50%; margin-top: -1rem; l ...