gpt4 book ai didi

ruby-on-rails - Ruby on Rails - Git 分支工作流程

转载 作者:太空宇宙 更新时间:2023-11-03 17:31:24 25 4
gpt4 key购买 nike

我知道这是一个简单的概念,但在研究了几个网站后还是没有掌握它。

我有一个 Ruby On Rails 项目并使用 git 来管理源代码。我有一个生产就绪的快照并初始化 git,这样它就有一个 master(使用 git init、git add -A 和 git commit -m)。

现在我想尝试一个新功能,所以我用 git checkout -b test 创建了一个名为“test”的分支

现在在测试中我尝试使用 rails g scaffold UserToken username:string 的新脚手架

脚手架创建了所有 ROR 文件,我执行了 rake db:migrate 更新数据库。然后我进入 Rails 控制台并测试将记录添加到数据库,然后开始更新其他生成的脚手架模型文件。

午饭后我回来,决定放弃这一切。

问题 - (在我自己尝试之后)是回到 master 的唯一方法是 git add -A,git commit -m 然后 git checkout master ?我真的必须添加并提交才能回到 master 吗? (这确实有效;但是我不认为我掌握了 git 中的一些基本知识,我会提交一些我要废弃的东西)

接下来,如果我执行上述操作(同样我认为这不对),当我回到 master 时,我确实看到我的脚手架文件以及迁移文件(创建表)和模式都消失了。 rb反射(reflect)在分支中生成的表不存在。

到目前为止还不错:

但是,如果我进入实际数据库,表仍然存在。在 ROR/Git 中我缺少什么在分支中测试某些东西然后放弃它的基本原理?

更新#1

因此 Stash 似乎没有帮助: stash 没有帮助。

Steps:  
rails new test_app
git init
git add -A
git commit -m 'initial commit'

git checkout -b newfeatures
rails g scaffold UserToken username:string coin:integer

files get generated...
sqlite3 db/development.sqlite3 show that there is now a table called user_tokens:

git stash save
git checkout master

现在在 Master 中,但是所有脚手架文件仍然存在(并且不应该存在)

最佳答案

这里有两个问题:

首先:如何在不提交正在进行的工作的情况下在分支之间移动?

要在分支之间移动而无需提交您的工作,您可以使用 git stash

git stash help
Usage: git stash list [<options>]
or: git stash show [<stash>]
or: git stash drop [-q|--quiet] [<stash>]
or: git stash ( pop | apply ) [--index] [-q|--quiet] [<stash>]
or: git stash branch <branchname> [<stash>]
or: git stash [save [--patch] [-k|--[no-]keep-index] [-q|--quiet] [<message>]]
or: git stash clear

一旦你存储了你的工作,你就可以毫无问题地在分支之间切换。 请注意,您希望存储的文件必须首先通过 git add 添加到 git 分支。未添加到 git 的文件更改(包括创建)不会被跟踪。因此,它们就像通用文件系统的任何其他部分一样,并且在各个分支中保持可见

第二:为什么我在一个分支中的数据库迁移更改会出现在另一个分支中?

因为数据库管理器不是 git 的一部分。无论您修改什么 DBMS,这些更改都会通过 DBMS 持久化。如果您想将分支迁移分开,那么您需要为每个分支迁移一个单独的数据库实例。

如果您将 git 分支想象成一个文件系统模板,它可能会有所帮助。当您切换到另一个分支时,该分支的模板会用其控制的任何内容覆盖您现有的文件系统。其他一切都被忽略。当您提交时,您正在更新该分支的模板。但是,您的所有工作实际上都是在一个真正的文件系统中完成的。

这意味着您对 git 控制之外的文件系统所做的事情在所有分支中仍然可见。

关于ruby-on-rails - Ruby on Rails - Git 分支工作流程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35367597/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com