JIYIK CN >

Current Location:Home > Learning > OPERATING SYSTEM > Git >

Cherry-Pick Merge Commits in Git

Author:JIYIK Last Updated:2025/03/29 Views:

When multiple developers from the same team are working on a project, regardless of the complexity of the project, handling and managing changes between Git branches becomes very difficult.

Sometimes, we need to merge some specific commits into another branch instead of merging the entire branch, and for this, we use a fundamental tool in Git known as cherry picking.

Cherry picking is a great tool when it comes to selecting just one commit from the entire list of commits in a repository branch.


git cherry-pickCommands in Git

git cherry-pickis an influential command that allows moving random Git commits from a branch in the repository and adding them to the repository you are currently working on HEAD. This command also helps in undoing changes related to past developments of your team.

For example, if we accidentally made a commit to the wrong branch, we will move to the correct branch and cherry-pick the commit into the correct location in the new branch in the repository.

When using git mergeor git rebase, all commits from one branch are mixed. While cherry-pickthe command enables us to select selected commits to assimilate.


Cherry-Pick Merge Commits in Git

Cherry-picking a merge commit is not as easy as it seems. When we perform the merge process, we work with two branches of the same repository at the same time.

For example, use the Git command to parent-Bmerge branch into parent-Abranch.

So, when we want to cherry-pick a specific commit, i.e., merge with two parent branches, we need to -mtell the -p option to cherry-pickthe -p command which commit it should use diffagainst. We will use -p in the following command commit hashto mention the specific parent branch.

The syntax for the above case is explained below.

git cherry-pick -m <commit hash>

Let us explain this situation with the following example of the above command.

M - N - O - P - Q (branch A)
     \     /
      R - S - T (branch B)

As shown above, Pit is a merge commit. If we run git cherry-pickthe command, Git will pass a warning about it.

So now we have to mention the parent branch number with the commit id. It will be executed in the following command.

git cherry-pick -m 1 P

This command will get all commits cherry-pickfrom the above example .O- P

We can also use the following command to perform the above operations.

git cherry-pick -m 2 P

This will R- S- Pselect all commits from in the above example.

It destroys all the changes we made in the parent and that we didn't define in that commit -m.

For reprinting, please send an email to 1244347461@qq.com for approval. After obtaining the author's consent, kindly include the source as a link.

Article URL:

Related Articles

Fatal: Refusing to Merge Unrelated Histories error in Git

Publish Date:2025/03/29 Views:123 Category:Git

This article outlines the steps required to resolve the fatal: refusing to merge unrelated histories error in Git. We usually encounter such errors when trying to merge two unrelated Git projects into one branch. It pops up when the receivi

Clone a remote repository using submodules in Git

Publish Date:2025/03/29 Views:58 Category:Git

This article will discuss how to clone a remote Git repository using submodules. We will also create a submodule and push it to the remote repository before cloning it. Clone a remote repository using submodules in Git We clone our reposito

Using SSH keys to clone a repository or branch in Git

Publish Date:2025/03/29 Views:138 Category:Git

SSH Git cloning provides a secure way to clone remote repositories. This tutorial shows the complete method of Git cloning using SSH keys - how to generate SSH keys, set up SSH in Git, and use SSH keys for Git cloning. We also showed some u

Clone the repository in Git

Publish Date:2025/03/29 Views:146 Category:Git

Git is known as one of the best and most demanding version control systems for all developers around the world. As of now, it is a distributed version control system that utilizes its local repository and delegates the typical version contr

Clone Git using username and password

Publish Date:2025/03/29 Views:75 Category:Git

In this article, we will learn how to clone an existing repository using username and password in Git. In Git, we use the command git clone to clone an existing remote repository to our local computer. When we call git clone the command, we

Clone into a non-empty Git directory

Publish Date:2025/03/29 Views:108 Category:Git

This article will show you how to clone a Git repository to a non-empty folder. This operation comes in handy when you want to merge files from a remote repository with files in your current local repository. In Git, clone into a non-empty

Clone all branches in Git

Publish Date:2025/03/29 Views:132 Category:Git

When developing software using Git, you can create different branches for different features. This article will explain how to clone all different branches from remote to local in Git. Git clone all branches When using Git, you may need to

Clone a private repository in Git

Publish Date:2025/03/29 Views:106 Category:Git

This article will teach you how to use Git to clone a private repository hosted on Github. Git is a version control system used to track changes in a project directory. Git uses commits for such purposes. Github provides Internet hosting fo

Force pull overwrite in Git

Publish Date:2025/03/29 Views:119 Category:Git

Git is the most popular and demanded version control system today. The user interface of Git is similar to other version control systems. We can log in, clone the repository and make commits. However, Git has some significant differences th

Scan to Read All Tech Tutorials

Social Media
  • https://www.github.com/onmpw
  • qq:1244347461

Recommended

Tags

Scan the Code
Easier Access Tutorial