版本管理工具SVN学习(一):简单的SVN命令,兼对比Git
新公司用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的更多相关文章
- SVN学习之windows下svn的安装
svn是apache的一个开源项目,全称为subversion.是一个基于版本的项目管理软件,一般在多人开发的项目中使用,目前svn已经替代了原来的cvs.大多数情况下,svn服务安装在linux服务 ...
- SVN学习(二)——SVN 提交、更新、解决冲突等操作步骤
1. 纳入版本控制 ①新建文件abc.txt ②在文件上点右键 ③添加后文件图标发生变化 2. 提交 ①使用TortoiseSVN可以提交具体某一个文件,或某一个目录下的所有改变.方法就是在想要提交的 ...
- SVN学习(一)——SVN 检出文件步骤、图标显示及含义
May, I come... 1. 创建一个目录用来存放检出得到的文件,例如MyCRM 2. 直接进入目录MyCRM,点右键 3. 可以看到检出得到的文件 此时文件图标上没有任何标识.可能你会想到通过 ...
- python学习:简单的wc命令实现
#!/usr/bin/python import sys import os try: fn = sys.argv[1] except IndexError: print &q ...
- Github学习进阶-初露锋芒,通过命令行将本地git仓库推送到Github上面的仓库
前提: 1. 需要安装git 客户端. 能打开 git bash 命令行窗口. 2. 生成了ssh 秘钥,并添加到了Github上面. 一.在Github上面建立一个git仓库. 点击 + 号,在 ...
- 版本管理工具 —— SVN
想想我们在开发过程中是不是会遇到这样的情况: 今天写了很长的一段代码,觉得不合理,然后删了,第二天突然发现昨天的那段代码才是正确的,那怎么办,也无法撤销删除的代码? 还有团队中多人共同开发一个项目,如 ...
- SVN学习——简单入门之创建仓库、导入、检出(一)
从刚刚参加工作就开始使用svn,清晰的记得那年师姐比较生气的来找我:“你怎么又不更新就提交代码了,把我写的都给覆盖掉了”,哈哈~ 虽然一直在用svn,不过在日常工作中主要用到的是简单的操作,而且大多数 ...
- SVN版本控制工具使用学习
SVN版本控制工具使用学习 Subversion是优秀的版本控制工具. 1.下载和搭建SVN服务器 http://subversion.apache.org/packages.html 类型有5种,推 ...
- 在Eclipse中使用版本管理工具SVN
近日工程中,逐渐感觉到原来复制粘贴代码的笨重,突然想起以前有人和我说起过Git和SVN之类的版本管理工具.由于平时主要是写Java代码,所以能够在Eclipse中使用SVN工具进行版本管理就可以说是很 ...
随机推荐
- TensorFlow安装-ubuntu
windows下某些tensorflow例子跑不成功,比如https://www.tensorflow.org/tutorials/wide 中的例子报下面的错误:' 'NoneType' objec ...
- iOS 中的单例设计模式
单例设计模式:在它的核心结构中只包含一个被称为单例类的特殊类.例如文件管理中的NSUserDefault,应用程序中的UIApplication,整个应用程序就这一个单例类,负责应用程序的一些操作,单 ...
- STM32GPIO口8种模式细致分析(类比51单片机)
关于STM32GPIO口的8种工作模式,我们先引出一些问题? STM32GPIO口如果既要输入又要输出怎么办? 1.浮空输入模式 上图红色的表示便是浮空输入的过程,外部输入时0读出的就是0,外部输入时 ...
- HTML5 WebSocket和后端C#通信
1.使用 HTML5 开发离线应用 http://www.ibm.com/developerworks/cn/web/1011_guozb_html5off/ 2.利用html 5 websocket ...
- Linux开机启动(bootstrap)下
init process (根据boot loader的选项,Linux此时可以进入单用户模式(single user mode).在此模式下,初始脚本还没有开始执行,我们可以检测并修复计算机可能存在 ...
- Java集合常见面试题集锦
1.介绍Collection框架的结构 集合是Java中的一个非常重要的一个知识点,主要分为List.Set.Map.Queue三大数据结构.它们在Java中的结构关系如下: Collection接口 ...
- Python多线程Selenium跨浏览器测试
前言 在web测试中,不可避免的一个测试就是浏览器兼容性测试,在没有自动化测试前,我们总是苦逼的在一台或多台机器上安装N种浏览器,然后手工在不同的浏览器上验证主业务流程和关键功能模块功能,以检测不同浏 ...
- firstElementChild&&firstChild
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...
- MySQL学习笔记(二)—查询
一.多表连接查询 新建两张表t_user.t_order. 1.内连接 返回满足条件的所有记录. (1)显式内连接 使用inner join关键字,在on ...
- 1129: 零起点学算法36——3n+1问题
1129: 零起点学算法36--3n+1问题 Time Limit: 1 Sec Memory Limit: 64 MB 64bit IO Format: %lldSubmitted: 4541 ...