JIYIK CN >

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

Use git log with a range to display the commit history of a branch

Author:JIYIK Last Updated:2025/04/02 Views:

git logThere are many options for limiting the number of commits you can get from your repository's history. We demonstrated git loghow rangeto use the double-dot syntax, the caret ^operator, --notoptions, and several shortcuts to help us view only git committhe 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 logGit 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 logThe 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 optionsprovide correct range values ​​in these , we can git showcommit 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 branch2but not from branch1.

Suppose we mastercreate a new one from experiment_branch. We then commit to both branches, but don't merge them yet.

If we now experiment_branchdo a simple on git log, it will show the full history, including the commits we made experiment_branchon before creating .master

Submit on master before experiment

This is not very helpful behavior. A common use case is when we only want to see experiment_branchthe unmerged commits on .

We do this using the following command.

git log master..experiment_branch

All commits reachable from experiment_branch, but not masterreachable from (essentially, all unmerged commits on the experimental branch).

Git commit history for branch double-dot syntax

We can also flip the order of the branches to see the state of the we are about to merge experiment_branchour master.

Our masterlooks like this:

Mastering new commits after experimenting

When we do this:

git log experiment_branch..master

After creating our experiment branch, we only see masternew commits on .

new commits master double dot


Use git logthe 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 checkoutuse this with a sensible choice of to shorten our git logcommands.

First, we switch to our experimental branch.

git checkout experiment_branch

Now HEADpoint 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.

git double dot


Use logto show commits on the current branch, useful option to only see the last few commits

Our experiment_branchmay have a long history, with many unmerged commits.

Experiment with long history and many unmerged commits

In this case, we probably only want to see the last few commits.

git log -2 master..

-2option to show only the last 2 commits in the history subset we selected.

Show only the last few commits in history


^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

Show commit history for the branch caret


--notGit commit history for a branch with the -b option

We can also use the -p option before the branch name --notto 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_branchshowing the unmerged commits on our .

Showing commit history for a branch is not an option

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

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

Scan to Read All Tech Tutorials

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

Recommended

Tags

Scan the Code
Easier Access Tutorial