踩坑日记:为什么 .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 终于可以正常工作了

相关推荐
To_OC3 天前
万字解析《JS 语言精粹》之第五章:继承 5 大核心精髓(JS 原型核心)
前端·javascript·代码规范
Coffeeee3 天前
闲聊几句,Android老哥们,你们多久没做技改需求了
android·程序员·代码规范
和你看星星3 天前
Git rerere:让重复冲突只解决一次
git
饼干哥哥3 天前
扣子3.0测评:我让 Codex 和 Claude Code 住同一个桌面,结果它们打架了!
人工智能·开源·代码规范
豆包MarsCode5 天前
Loop Engineering 到底是什么?看这一篇就够了
trae
码哥字节5 天前
为什么 Claude Code 读你的代码库,光靠 embedding 根本不够?
claude·代码规范
嘻嘻仙人6 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson6 天前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
沉浸学习的匿名网友7 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git