Use git log with a range to display the commit history of a branch
git log
There are many options for limiting the number of commits you can get from your repository's history. We demonstrated git log
how range
to use the double-dot syntax, the caret ^
operator, --not
options, and several shortcuts to help us view only git commit
the history of a branch.
Git draws its power from this rich revision query system, enabling users to manage their branches and design efficient workflows with them.
git log
Git commit history for branches
using and advanced restriction options
Git repositories can grow large with long commit histories. In such cases, viewing the full history is not very helpful.
git log
The command provides us with many useful options to extract the subset of commits we need from the repository history.
git log [formatting options] [limiting options]
[formatting options]
Lets us display different information about our commits, while [limiting options]
helps us select the commit we want to see.
When we limiting options
provide correct range values in these , we can git show
commit on the current branch.
<branch1>..<branch2>
Git commit history for branches
using double-dot syntax
The double-dot syntax shows those commits that we can reach from branch2
but not from branch1
.
Suppose we master
create a new one from experiment_branch
. We then commit to both branches, but don't merge them yet.
If we now experiment_branch
do a simple on git log
, it will show the full history, including the commits we made experiment_branch
on before creating .master
This is not very helpful behavior. A common use case is when we only want to see experiment_branch
the unmerged commits on .
We do this using the following command.
git log master..experiment_branch
All commits reachable from experiment_branch
, but not master
reachable from (essentially, all unmerged commits on the experimental branch).
We can also flip the order of the branches to see the state of the we are about to merge experiment_branch
our master
.
Our master
looks like this:
When we do this:
git log experiment_branch..master
After creating our experiment branch, we only see master
new commits on .
Use git log
the helpful shortcut of to save a few characters from typing to display the Git commit history for a branch
If we don't provide either of the two branches in the double-dot syntax, Git will default them to HEAD
.
We can git checkout
use this with a sensible choice of to shorten our git log
commands.
First, we switch to our experimental branch.
git checkout experiment_branch
Now HEAD
point to experiment_branch
.
We now use a shorter version of the two-dot range syntax, omitting the right branch operand.
git log master..
Git defaults the correct branch to current HEAD
, ours experiment_branch
, and we get the same history of unmerged commits as above.
Use log
to show commits on the current branch, useful option to only see the last few commits
Our experiment_branch
may have a long history, with many unmerged commits.
In this case, we probably only want to see the last few commits.
git log -2 master..
-2
option to show only the last 2 commits in the history subset we selected.
^
Git commit history for a branch
with the caret operator
The caret operator ^
excludes all commits that are reachable from the branch it operates on. We can use this to only show the history of the current branch.
git log ^master experiment_branch
--not
Git commit history for a branch
with the -b option
We can also use the -p option before the branch name --not
to achieve the same result. This will not include all commits reachable from that branch.
git log experiment_branch --not master
We see that it does the same thing, only experiment_branch
showing the unmerged commits on our .
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.
Related Articles
Push to a specific branch in Git
Publish Date:2025/04/02 Views:53 Category:Git
-
In Git, we use branches to develop independent features directly from the main workflow of the project. Since Git is considered to be the best version control system so far, we have local and remote branches in our repository for different
Solve the Git Push Everything Up-To-Date Problem
Publish Date:2025/04/02 Views:120 Category:Git
-
Git is a free, open source version control system designed to work with projects quickly and efficiently. You can make changes to your repo and push them to master branches. This article explains how to use git push the command to resolve e
Git merge development branch into feature branch
Publish Date:2025/04/02 Views:126 Category:Git
-
Creating new branches and merging them is considered to be the most powerful tool of Git. The ability of Git to create new branches and merge them into the development code is very useful for developers working in a team environment. This f
Understanding Git conflict markers
Publish Date:2025/04/02 Views:112 Category:Git
-
In this article, we will discuss git conflict markers. Understanding Git conflict markers When pulling changes from a remote repository, you may encounter merge conflicts. Merge conflict files can sometimes be confusing. A typical merge con
Selectively merge changes from different branches in Git
Publish Date:2025/04/02 Views:116 Category:Git
-
This article will discuss merging specific changes from one branch to another. As we know, when merging branches, Git merges all files without exception. You may find yourself in a scenario where you have some commits in one branch and you
Complete the merge after resolving conflicts in Git
Publish Date:2025/04/02 Views:63 Category:Git
-
This article describes the process of completing a merge after resolving merge conflicts in Git. We will go through the merge steps, resolve the conflicts, and complete the merge. Complete the merge after resolving conflicts in Git For a si
Merge the development branch into Master in Git
Publish Date:2025/04/02 Views:167 Category:Git
-
This article provides an overview of merging a development branch into the master branch. Often we find ourselves creating a branch outside of the master branch for development. Once we are happy with the changes, we can merge them into mas
Recovering a conflicting Git merge
Publish Date:2025/04/02 Views:160 Category:Git
-
This article explains the revert command when a merge conflict occurs git merge . We will also take a quick look at how to undo a git merge that was successful and has been pushed to a remote repository. Recovering a conflicting Git merge I
Git merge-base determines the most recent common ancestor of two branches
Publish Date:2025/04/02 Views:126 Category:Git
-
This article explains how we can find the most recent common ancestor commit in Git. This comes in handy when you create a branch or merge one branch into another. Without further ado, let’s get into today’s topic. Determine the most re