Essential Git Commands Every Developer Wish To Know

Git is an essential tool for every developer, enabling efficient version control and collaboration. Here’s a list of the most important Git commands you should master. 1. Git Configuration Before you start using Git, configure your username and email: git config --global user.name "Your Name" git config --global user.email "your.email@example.com" Check your configuration with: git config --list 2. Initializing and Cloning Repositories To start a new Git repository: git init To clone an existing repository: git clone https://github.com/user/repository.git 3. Staging and Committing Changes Check the status of your repository: git status Stage files for commit: git add filename # Add a specific file git add . # Add all changes Commit changes: git commit -m "Your commit message" 4. Branching and Merging Create a new branch: git branch new-branch Switch to the new branch: git checkout new-branch Alternatively, create and switch in one command: git checkout -b new-branch Merge a branch into the main branch: git checkout main git merge new-branch Delete a branch: git branch -d new-branch 5. Working with Remote Repositories To add a remote repository: git remote add origin https://github.com/user/repository.git Push changes to a remote repository: git push origin branch-name Fetch changes from a remote repository: git fetch origin Pull changes and merge: git pull origin branch-name 6. Undoing Changes To undo changes in a file before staging: git checkout -- filename To remove a file from staging: git reset filename To undo the last commit (without losing changes): git reset --soft HEAD~1 To undo the last commit (discard changes): git reset --hard HEAD~1 7. Checking History and Logs View commit history: git log View commit history in a single line: git log --oneline --graph --decorate Check the last commit: git show HEAD 8. Stashing Changes If you need to save changes temporarily without committing: git stash To apply stashed changes: git stash pop To list all stashes: git stash list 9. Resolving Merge Conflicts When merging branches, you may encounter conflicts. Use: git status Edit the conflicting files, then add and commit them: git add . git commit -m "Resolved merge conflict" 10. Deleting Files and Commits To remove a file and commit the deletion: git rm filename git commit -m "Deleted filename" To delete the last commit: git reset --hard HEAD~1 11. Amending the Last Commit (Modify Commit Without Creating a New One) git commit --amend -m "Updated commit message" ✅ Use this when you need to change the last commit’s message or include new changes without creating a new commit. 12. Finding and Fixing a Bad Commit (Bisecting) git bisect start git bisect bad # Mark current commit as bad git bisect good # Mark an older commit as good ✅ Helps in debugging when you need to find the exact commit that introduced a bug. Git will guide you through a binary search of commits. 13. Cherry-Picking Specific Commits git cherry-pick ✅ Use when you need to apply a specific commit from one branch to another without merging everything. 14. Recovering Deleted Branches git reflog git checkout -b recovered_branch ✅ If you accidentally delete a branch, git reflog helps you find its last commit and recover it. 15. Squashing Multiple Commits Into One git rebase -i HEAD~3 ✅ Great for cleaning up your commit history before merging a feature branch. 16. Temporarily Shelving Changes (Saving Work Without Committing) git stash push -m "Work in progress" git stash list git stash pop ✅ Ideal when you need to switch branches quickly without committing incomplete work. 17. Undoing a Pushed Commit (Without Affecting Others) git revert git push origin main ✅ Creates a new commit that undoes the changes of a specific commit, keeping history intact. 18. Clearing Local Commits Before Pushing git reset --soft HEAD~3 # Keeps changes git reset --hard HEAD~3 # Discards changes ✅ Use --soft to uncommit but keep changes or --hard to erase them completely. 19. Forcing a Pull to Overwrite Local Changes git fetch --all git reset --hard origin/main ✅ Use when you want your local branch to exactly match the remote branch, overwriting local changes. 20. Finding Who Made a Change to a Specific Line git blame -L 42,42 filename.txt ✅ Helps track down who changed a specific line and when, useful for debugging and accountabil

Feb 22, 2025 - 10:36
 0
Essential Git Commands Every Developer Wish To Know

Git is an essential tool for every developer, enabling efficient version control and collaboration. Here’s a list of the most important Git commands you should master.

1. Git Configuration

Before you start using Git, configure your username and email:

git config --global user.name "Your Name"
git config --global user.email "your.email@example.com"

Check your configuration with:

git config --list

2. Initializing and Cloning Repositories

To start a new Git repository:

git init

To clone an existing repository:

git clone https://github.com/user/repository.git

3. Staging and Committing Changes

Check the status of your repository:

git status

Stage files for commit:

git add filename    # Add a specific file
git add .           # Add all changes

Commit changes:

git commit -m "Your commit message"

4. Branching and Merging

Create a new branch:

git branch new-branch

Switch to the new branch:

git checkout new-branch

Alternatively, create and switch in one command:

git checkout -b new-branch

Merge a branch into the main branch:

git checkout main
git merge new-branch

Delete a branch:

git branch -d new-branch

5. Working with Remote Repositories

To add a remote repository:

git remote add origin https://github.com/user/repository.git

Push changes to a remote repository:

git push origin branch-name

Fetch changes from a remote repository:

git fetch origin

Pull changes and merge:

git pull origin branch-name

6. Undoing Changes

To undo changes in a file before staging:

git checkout -- filename

To remove a file from staging:

git reset filename

To undo the last commit (without losing changes):

git reset --soft HEAD~1

To undo the last commit (discard changes):

git reset --hard HEAD~1

7. Checking History and Logs

View commit history:

git log

View commit history in a single line:

git log --oneline --graph --decorate

Check the last commit:

git show HEAD

8. Stashing Changes

If you need to save changes temporarily without committing:

git stash

To apply stashed changes:

git stash pop

To list all stashes:

git stash list

9. Resolving Merge Conflicts

When merging branches, you may encounter conflicts. Use:

git status

Edit the conflicting files, then add and commit them:

git add .
git commit -m "Resolved merge conflict"

10. Deleting Files and Commits

To remove a file and commit the deletion:

git rm filename
git commit -m "Deleted filename"

To delete the last commit:

git reset --hard HEAD~1

11. Amending the Last Commit (Modify Commit Without Creating a New One)

git commit --amend -m "Updated commit message"

✅ Use this when you need to change the last commit’s message or include new changes without creating a new commit.

12. Finding and Fixing a Bad Commit (Bisecting)

git bisect start
git bisect bad  # Mark current commit as bad
git bisect good   # Mark an older commit as good

✅ Helps in debugging when you need to find the exact commit that introduced a bug. Git will guide you through a binary search of commits.

13. Cherry-Picking Specific Commits

git cherry-pick 

✅ Use when you need to apply a specific commit from one branch to another without merging everything.

14. Recovering Deleted Branches

git reflog
git checkout -b recovered_branch 

✅ If you accidentally delete a branch, git reflog helps you find its last commit and recover it.

15. Squashing Multiple Commits Into One

git rebase -i HEAD~3

✅ Great for cleaning up your commit history before merging a feature branch.

16. Temporarily Shelving Changes (Saving Work Without Committing)

git stash push -m "Work in progress"
git stash list
git stash pop

✅ Ideal when you need to switch branches quickly without committing incomplete work.

17. Undoing a Pushed Commit (Without Affecting Others)

git revert 
git push origin main

✅ Creates a new commit that undoes the changes of a specific commit, keeping history intact.

18. Clearing Local Commits Before Pushing

git reset --soft HEAD~3  # Keeps changes
git reset --hard HEAD~3  # Discards changes

✅ Use --soft to uncommit but keep changes or --hard to erase them completely.

19. Forcing a Pull to Overwrite Local Changes

git fetch --all
git reset --hard origin/main

✅ Use when you want your local branch to exactly match the remote branch, overwriting local changes.

20. Finding Who Made a Change to a Specific Line

git blame -L 42,42 filename.txt

✅ Helps track down who changed a specific line and when, useful for debugging and accountability.

These commands help developers handle tricky Git situations efficiently. Which of these have you used, or do you have any nightmare Git experiences? Let me know!