Git---变基(git_rebase)操作之合并多次提交,美化log记录

2024-03-29 16:52

本文主要是介绍Git---变基(git_rebase)操作之合并多次提交,美化log记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

该总结主要用于多个提交,最后做汇总

目的是优化简化log日志

修改历史commit信息记录

 git rebase 常用操作命令

git rebase --continue表示继续下一个冲突或者下一个变基操作
git rebase --skip表示跳过当前冲突或当前变基操作
git rebase --abort表示退出rebase模式

一、改变最近一次提交说明

// 可以直接用 --amend 的属性实现修改最近的一次提交信息
// 1. git add 操作后的文件
// 上次提交时描述错别字想修改:提叫信息 ==> 提交信息
// 2. git commit --amend -m '修正的信息' 
// 或者这样写:
// 2. git commit --amend 会弹出紧邻的上次提交信息,直接修改后(:wq),即可

二、改变多次提交说明

改变一个或者多个历史提交信息

// 这是一条衍生命令,涉及的所有提交都会被重写(即便没有改动对应的记录说明)
git rebase -i HEAD~3
# 这里说明下下面的命令可以依次改动多个命令执行,顺序是依次执行,自上而下!!!
# 不过这里不推荐,尽量一个功能改动执行一次变基操作!!!pick aac47c2 提交getters中token函数
pick 327e0b3 添加fieldId获取方法
pick 933cb5d getters添加userInfo获取方法# Rebase a2cc4e4..933cb5d onto a2cc4e4 (3 commands)

 变基界面里面的命令说明

# Commands:
# p, pick <commit> = use commit
# p: 默认的选项,表示使用该提交,保留该commit,不做任何处理# r, reword <commit> = use commit, but edit the commit message
# r: (会改变hash值)重写提交信息,比如第二个信息前面pick改为r,
#    退出后会进入到另一个编辑界面(包含改为r的信息)
#    这里改的话,改对应的commit信息,退出后直接结束变基操作了,多个r操作(会连续跳进信息修改的)。# e, edit <commit> = use commit, but stop for amending
# e: (会改变hash值)将需要改动的信息pick改为edit(e),之后退出保存。会停留在对应的位置之后执行: git commit --amend 进入编辑页面修改commit信息之后执行: git rebase --continue 去继续操作修改完成rebase流程// 对于多个e的情况,后期尝试是否连续stop!!!(多个e操作,会连续stop的)# s, squash <commit> = use commit, but meld into previous commit
# s: 使用提交,但是合并到先前的提交中。即融合到该列表中的其中未改为s的提交中(暂时理解)
#    最重要的一点,在多个pick、记录里面,去最前面至少要有一个未改动的pick作为根合并的对象# d, drop <commit> = remove commit
# d:移除掉对应的提交,同时对应的改动也会被撤掉!!!慎用!!!

通俗介绍如下图

p,pick:保留该commit(缩写:p)
r,reword:保留该commit,但我需要修改该commit的注释(缩写:r)
e,edit:保留该commit, 但我要停下来修改该提交(不仅仅修改注释)(缩写:e)
s,squash:将该commit和前⼀个commit合并(缩写:s)
f,fixup:将该commit和前⼀个commit合并,但我不要保留该提交的注释信息(缩写:f)
x,exec:执⾏shell命令(缩写:x)
d,drop:我要丢弃该commit(缩写:d)经常⽤到的是pick、edit、squash、fixup

 rebase的常用操作:

git rebase --continue表示继续下一个冲突或者下一个变基操作
git rebase --skip表示跳过当前冲突或当前变基操作
git rebase --abort表示退出rebase模式 

友情提示下:

这些变基操作,主要针对当前分支的操作,即主要修改当前分支的提交信息或者优化当前分支的提交信息


不建议将公共分支进行编辑操作,这样会影响到其他的开发者,可以自己分支间操作使用,个人一般用来修改提交历史记录。

这篇关于Git---变基(git_rebase)操作之合并多次提交,美化log记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/859126

相关文章

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-