- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我知道这是一个简单的概念,但在研究了几个网站后还是没有掌握它。
我有一个 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/
sanitize 是什么意思在 Rails 中是什么意思? 我正在阅读 CanCanCan 的文档.它说: When using strong_parameters or Rails 4+, you
在过去的几个月里,我感觉自己对 Ruby on Rails (RoR) 开发的了解达到了极限。我为大/小客户和 friend /爱好项目开发了大大小小的应用程序。我知道如何开发这些应用程序,但开始感觉
我昨天参加了一个关于扩展 Rails 的聚会,其中一个主题是 Hexagonal Rails。然而,我只做了一年的 Rails,对 MVC 结构非常满意(也许太舒服了),所以我不太了解适配器和消息队列
我使用多个 Rails 应用程序,一些在 Rails 3.2/Ruby 2.0 上,一些在 Rails 2.3/Ruby 1.8.7 上。 他们的共同点是,随着他们的成长和添加更多的依赖项/ gem
这个问题在这里已经有了答案: Using Rails-UJS in JS modules (Rails 6 with webpacker) (5 个答案) 关闭 3 年前。 我正在尝试使用 UJS
我正在开发一个当前使用 Rails 1.2 的 Rails 应用程序,所以我现在离最新的稳定版本(Rails 2.3)还有很长的路要走。 我应该如何进行迁移到更新版本的 Rails 的过程? 我应该一
尝试按照 Ryan Bates Backbone.js 教程构建抽奖应用程序,但我已经遇到了第一段代码的问题。在 application.js 的 init 函数中,他初始化了 Raffler 路由的
我正在使用 Rails 3.2 并且我有一个数据库表,我想在其中找到符合以下条件的所有行: a = true and b = true and ( 0 true, :b =>
我有一个用户类和一个联系人,其中联系人是用户的子类。这两个类都存储在用户表中。 我的联系人可能有也可能没有电子邮件地址,而我的用户需要一个电子邮件地址(我的用户模型定义中有 validates_pre
我正在编写一个教程,我在其中演示了一些 rails 命令。在我的机器上 rails和 script/rails两者都同样有效。有“首选”形式吗?两者中哪一个更普遍? 最佳答案 当您运行 rails 时
我正在寻找有关通过我的应用程序前进的最佳方式的建议,这是我首次开始集成Elasticsearch。我是一名初学者,但是热衷于深入研究,以便原谅任何明显的错误! 我遵循了http://www.sitep
我刚刚用 Rails new 启动了一个新的 Rails 应用程序,将默认数据库设置更改为 PostgresSQL。我用 bin/rails s 启动服务器,结果很奇怪 2016-04-21 05:0
我收到一个参数并希望它是这样的字符串: "abc,efg" 或者像这样的数组 ["abc","efg"] 在第一种情况下,我想将它转换成一个数组,什么是好的方法? 这是我的想法 if params[:
我刚刚用 Rails new 启动了一个新的 Rails 应用程序,将默认数据库设置更改为 PostgresSQL。我用 bin/rails s 启动服务器,结果很奇怪 2016-04-21 05:0
我收到一个参数并希望它是这样的字符串: "abc,efg" 或者像这样的数组 ["abc","efg"] 在第一种情况下,我想将它转换成一个数组,什么是好的方法? 这是我的想法 if params[:
我有 Rails 4,这是我的默认版本(我仍然希望它是)。但我不想在我的电脑上添加 rails 3.2。在以下命令中:gem install rails -v 3.2.16 我有这个警告: railt
您好,我想使用 Sheevaplug 构建一个“Rails Brick”来自 Marvell(操作系统是开箱即用的 Ubuntu,但您可以在其上安装其他发行版)。它将成为家庭服务器和静音、低成本(99
我需要能够从 Rails 控制台发送我的 Rails 应用程序的 Postgres 数据库中所有未接受的邀请。 (我有一个名为 Invitations 的表,其中包含一个名为 accepted 的 b
validate :cannot_modify_if_locked, on: :update def cannot_modify_if_locked if self.locked erro
我正在学习教程(学习 Rails 播客),需要更改以下路由语法,以便它与 Rails 3.0 兼容。谁能帮忙? map.view_page ':name', :controller => 'viewe
我是一名优秀的程序员,十分优秀!