版本管理工具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工具进行版本管理就可以说是很 ...
随机推荐
- CSS左侧固定宽 右侧自适应(兼容所有浏览器)
左侧固定宽,右侧自适应屏幕宽: 左右两列,等高布局: 左右两列要求有最小高度,例如:200px;(当内容超出200时,会自动以等高的方式增高) 要求不用JS或CSS行为实现: 仔细分析试题要求,要达到 ...
- benchmark 库
性能测试的库 https://github.com/bestiejs/benchmark.js
- c++学习笔记之封装篇(上)
title: c++学习笔记之封装篇(上) date: 2017-03-12 18:59:01 tags: [c++,c,封装,类] categories: [学习,程序员,c/c++] --- 一. ...
- Android学习笔记---前传
在正式的撰写个人的学习笔记前,先对个人的学习经历做一个简要的介绍.座右铭:诚不欺我 1. 前言 本人非软件工程出身,属于半路出家,误打误撞进入这个行业,初心是软件开发的门槛低,自以为学习过C语言,轻度 ...
- 移动端ios 输入框fixed固定在底部 焦点时乱跳加遮盖问题的解决 转自zhangyunling 加个人项目解决方案
如果您有过移动端的开发经验,那么您是否碰到过这样的问题,一个页面有输入框,当这个输入框聚焦时,输入框在IOS下,被移动到手机屏幕的当中去了,而在Android端,有些浏览器的输入框,会被键盘盖住. 1 ...
- Spring框架下的单元测试
一.使用spring中对Junit框架的整合功能 除了junit4和spring的jar包,还需要spring-test.jar.引入如下依赖: <dependency> <grou ...
- 老李分享:接电话之uiautomator 1
老李分享:接电话之uiautomator poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:9 ...
- Maven项目搭建(三):Maven直接部署项目
上一章给大家讲解了如何使用Maven搭建SSM框架项目. 这次给大家介绍一下怎么使用Maven直接部署项目. Maven直接部署项目 1.新建系统变量CATALINA_HOME,值为:Tom ...
- Python__slots__详解
摘要 当一个类需要创建大量实例时,可以通过__slots__声明实例所需要的属性, 例如,class Foo(object): __slots__ = ['foo'].这样做带来以下优点: 更快的属性 ...
- backdrop-filter 和filter 写出高斯模糊效果 以及两者区别
http://www.w3cplus.com/css3/advanced-css-filters.html: backdrop-filter:blur(10px);只支持ios端:只作用于当前元素: ...