踩坑日记:为什么 .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 小时前
uni-app实现本地MQTT连接
前端·trae
小龙2 小时前
【Git 报错解决】本地无有效提交无法推送(`src refspec main does not match any`)
git·github·报错
小扶苏2 小时前
删除git全局账号信息并设置成新的账号密码命令
git
Greg_Zhong5 小时前
Git创建任务分支进行开发,最后合并主分支master【纯git命令执行过程】阐述
git
PPPHUANG5 小时前
一次 CompletableFuture 误用,如何耗尽 IO 线程池并拖垮整个系统
java·后端·代码规范
眯眼因为很困啦6 小时前
GitHub Fork 协作完整流程
前端·git·前端工程化
豆包MarsCode7 小时前
用第一性原理拆解 Agentic Coding:从理论到实操(上)
trae
zhouzhouya7 小时前
码上星辰,人间烟火:我的2025
前端·程序员·代码规范
AlexDeng8 小时前
Git 中模糊搜索分支名称并创建本地跟踪分支
git
程序员Agions8 小时前
程序员邪修手册:那些不能写进文档的骚操作
前端·后端·代码规范