踩坑日记:为什么 .gitignore 不起作用了

最近在为 Mathcheap 项目开发一个 Gemini API Key 代理工具,在做项目管理的时候遇到一个问题,之前误将本地的测试数据库提交到了代码中,发现这个问题后,希望通过在.gitignore 中添加了一行

bash 复制代码
# sqlite database
data.sqlite

希望可以让Git忽略掉当前代码中的 data.sqlite 数据库,可是 data.sqlte 依然显示在 "Chnages" 中

这是怎么回事?

解释原因

.gitignore 只会忽略"未被跟踪"的文件;一旦文件已经被 Git 跟踪并提交过,后续改动仍会显示在"Changes"。因为 data.sqlite 文件之前已经被我提交过了,所以仓库中 data.sqlite 已经被跟踪,所以即使在 .gitignore 加了规则,Git 仍会显示它的变更。

通常的做法是通过 git reset --soft HEAD~ 回溯到上次提交的状态,删除被不想被提交的文件, 在更新 .gitignore 就可以了。

但是如果已经提交很久了,回溯也很麻烦,就用下面的命令停止跟踪但保留本地文件:

bash 复制代码
git rm --cached data.sqlite
git commit -m "Stop tracking data.sqlite"

之后 .gitignoredata.sqlite 规则就会生效,新变更不会再出现在"Changes"。

检查忽略规则是否生效以及来自哪一条规则:

bash 复制代码
git check-ignore -v data.sqlite
# .gitignore:44:*.sqlite  data.sqlite

.gitignore 终于可以正常工作了

相关推荐
玉梅小洋1 小时前
Git 使用技巧——查看 Commit 修改文件的概要
git·github
Howie Zphile12 小时前
Git 拉 NocoBase 2.0 beta(next 分支),并“每天自动更新 + 自动编译 + 自动重启”
大数据·git·elasticsearch
吕司13 小时前
Git分支管理
git
黑屋里的马15 小时前
GitExtension下载、安装
git·gitextension
Geoking.15 小时前
Git 中的 Rebase 与 Merge:原理、区别与最佳实践
git
invicinble17 小时前
一文了解git
大数据·git·elasticsearch
我命由我1234517 小时前
Git 初始化本地仓库并推送到远程仓库解读
运维·服务器·经验分享·笔记·git·学习·学习方法
爱码小白17 小时前
Git学习笔记
笔记·git·学习
skywalk816318 小时前
sudo apt upgrade git 报错
git
玄同76518 小时前
TRAE Rules 高效使用指南:让 AI 更听话的秘密
ide·人工智能·ai编程·claude·cursor·trae