SVN版本回退

SVN提交过程如下,提交了5次错误的代码,1570是正确的,把版本回退到1570;

1575 错误提交5

1574 错误提交4

1573 错误提交3

1572 错误提交2

1571 错误提交1

1570 正确提交的版本

回退步骤

1. 更新到最新版本

svn update

2. 查看1570到1575之间的所有修改

svn diff -r 1570:1575

3. 撤销1571到1575的所有更改(回滚到1570)

svn merge -r HEAD:1570 .

4. 检查合并结果

svn status

5. 提交撤销操作

svn commit -m "回退到版本1570,撤销1571-1575的错误提交"

SVN提交过程如下,提交了5次(1571~1575)错误的代码,1570之前的版本是正确的,1576之后的版本是正确的,该怎么回退这5次错误的提交;

1578 正确提交3

1577 正确提交2

1576 正确提交1

1575 错误提交5

1574 错误提交4

1573 错误提交3

1572 错误提交2

1571 错误提交1

1570 正确提交的版本

1569 正确提交的版本

回退步骤

查看当前的 SVN 日志

svn log --limit 20

一次性撤销这 5 个错误的版本

svn merge -r1575:1570 .

注意:-r1575:1570表示从 1575 反向合并到 1570(不包括 1570),也就是撤销 1571~1575 的更改。

或者

svn merge -c -1575,-1574,-1573,-1572,-1571 .

如果这些错误提交和后续的正确提交修改了相同文件,可能会产生冲突,需要手动解决。

检查冲突:

svn status

解决冲突后,标记为已解决:

svn resolve --accept working 冲突文件路径

提交撤销更改

svn commit -m "Revert changes from r1571 to r1575, restore to r1570 state"

撤销提交后,运行测试确保代码回到正确状态,并与 r1570 的版本进行比较:

svn diff -r1570:HEAD

注意事项

这种方法不会删除历史记录,只是在最新版本上添加一个"反向修改"的提交,历史记录中仍然保留 r1571~r1575,但内容被撤销。

如果后续正确提交(r1576~r1578)依赖于错误提交的内容,可能需要手动调整代码逻辑。

如果你希望彻底删除历史记录(不推荐,会破坏版本连续性),可以使用 svnadmin dump和 filter工具,但这需要仓库管理员权限,并且会影响所有用户。

相关推荐
MAX_VALUE1 天前
svn迁移及版本升级
svn
长沙红胖子Qt5 天前
关于 sourceTree桥接管理远端svn仓库出现git时区差8小时无法同步 的解决方法
git·svn·时间差·8小时
芯有所享6 天前
【芯片设计中的版本管理:Git与SVN的实战选择指南】
经验分享·git·svn
无公害的小bug6 天前
MAC系统安装SVN教程
macos·svn
HoneyMoose15 天前
执行 git svn clone --stdlayout 命令无输出
git·svn
HoneyMoose15 天前
把 SVN 仓库转换为 Git 需要的 2 个命令
git·svn
JAVA面经实录91720 天前
Java开发工程基础完整手册(企业实战完整版)
java·开发语言·git·ci/cd·svn·github·intellij idea
长沙红胖子Qt23 天前
SVN培训笔记(四):使用sourceTree时,PC硬盘或者移动硬盘更换电脑后sourceTree无法拉取同步和推送已有项目管理的处理方法
svn·sourcetree管理svn·sourcetree迁移git·git svn
金融小师妹25 天前
AI多因子定价模型:美元强化与能源约束下 黄金反弹受限弹性解析
深度学习·svn·逻辑回归·能源
Irene199125 天前
推荐 win11 可用的 SVN 版本:64位,下载最新的 TortoiseSVN 1.14.x 版本
svn