草庐IT

generate-migrations-db

全部标签

ruby-on-rails - 运行 rake db :migrate 时,Rails 创建迁移以将列添加到表中会导致错误

我创建了一个名为“用户”的模型,我创建了一个新的迁移以将一些列添加到用户表中。现在,当我运行rakedb:migrate时,我得到以下b/c错误,它正在尝试再次创建用户表$rakedb:migrate==DeviseCreateUsers:migrating==============================================--create_table(:users)rakeaborted!Anerrorhasoccurred,alllatermigrationscanceled:Mysql::Error:Table'users'alreadyexists:CR

ruby-on-rails - 为什么 Ruby "script/generate"返回 "No such file or directory"?

我在使用script/generate时遇到问题。我正在关注treebasednavigation教程,它说使用script/plugininstallgit://github.com/rails/acts_as_tree.git或script/generatenifty_layout。我不断得到:Nosuchfileordirectory--script/plugin我试过这些变体:script/generatenifty_layoutrailsgeneratenifty_layoutrubyscript/generatenifty_layoutrubygeneratenifty_l

ruby-on-rails - Rails link_to :format => :xlsx not generating link to . xlsx 路径

如果我点击这个url:http://localhost:3000/reports/action.xlsx它会显示生成的xlsx文件。如果我有这样的link_to::xlsx%>它生成一个链接到这个页面:http://localhost:3000/reports/action为什么我使用:format=>:xlsx的link_to没有链接到正确的路径? 最佳答案 您的link_to和path略有偏差。你要格式是path助手的参数,而不是link_to。 关于ruby-on-rails-Ra

ruby-on-rails - 在 rake db :create 期间无法将 fixnum 转换为字符串

刚刚使用Rails3.0创建了一个新的博客应用我的模型很简单:classPost我使用了命令:railsgeneratescaffoldposttitle:stringbody:textetc.创建这些文件。现在我想使用以下方法生成数据库:rake数据库:创建我得到了错误:rakeaborted!can'tconvertFixnumintoString知道问题是什么吗?我正在学习本教程:http://sixrevisions.com/web-development/how-to-create-a-blog-from-scratch-using-ruby-on-rails/这是痕迹:**

ruby-on-rails - rails : Modifying a Model Generated by Scaffolding

如何修改使用建模生成的模型?例如,myModel模型原来有a、b、c列,但我现在想添加d列。 最佳答案 Rails3及更高版本使用以下代码:railsgeneratemigrationadd_fieldname_id_to_tablenamefieldname:stringrails2rubyscript/generatemigrationadd_fieldname_to_tablenamefieldname:string这不再有效并在Rails3中返回以下错误:ruby:Nosuchfileordirectory--script/

ruby-on-rails - 附加到 rake db :seed in rails and running it without duplicating data

Rakedb:seed使用应用程序的默认数据库值填充您的数据库,对吗?那么如果您已经有一个种子并且需要添加到它(您添加一个需要种子的新功能)怎么办?根据我的经验,当我再次运行rakedb:seed时,它已经添加了现有内容,因此现有内容变成了两倍。我需要的是添加一些种子,当运行时,它应该只添加最新的种子,而忽略现有的种子。我该怎么做?(我通常采用的肮脏的、菜鸟的方式是截断我的整个数据库然后再次运行种子,但这在生产中不是很聪明,对吧?) 最佳答案 更简洁的方法是使用find_or_create_by,如下所示:User.find_or_

ruby - 导轨 4 : Append to a "has_many" relation without saving to DB

在Rails3中,可以做类似some_post.comments.append(some_comment)的事情其中一些帖子是“有很多”评论的模型实例。我在Rails4中面临的问题是append方法现在保存到数据库(如push和),我只需要“附加”而不将附加的对象保存到数据库。我们如何在Rails4中实现这一点?我不能使用some_post.comments.build(some_comment.attributes)因为我需要保留some_comment中已经存在的其他关系实例。 最佳答案 在Rails中优雅地做到这一点非常困难。

ruby-on-rails - Rails Migrations 可以用来转换数据吗?

我正在尝试转换我的Rails应用程序中的列,为了论证,让我们假设我正在尝试将我的users表中的age列更改为字符串表示形式而不是int。在我的迁移中我有这个;def.selfupadd_column:users,:age_text,:stringusers=User.find(:all)users.eachdo|u|u.age_text=convert_to_text(u.age)u.saveendenddefself.convert_to_text(number)#codeheretoconvert1to'one'etcend但它似乎没有用,我在这里尝试的是否可以通过迁移实现?

ruby-on-rails - rails : Postgres permission denied to create database on rake db:create:all

我正在尝试创建用于开发和测试的postgres数据库。我正在使用:OSX优胜美地Rails版本:4.2.0git版本:2.2.2psql版本:9.4.0ruby版本:2.1.0p0自制软件版本:0.9.5gem文件:gem'pg'数据库.yml:default:&defaultadapter:postgresqlencoding:unicodepool:5development:rakedb:create:all返回PG::InsufficientPrivilege:ERROR:permissiondeniedtocreatedatabase:CREATEDATABASE"myapp_

ruby-on-rails - rails 迁移 : How to increase column data type size by using ROR migration

我的用户表登录列是String类型,限制为40个字符。现在我打算将限制增加到55个字符。任何人请让我知道我们如何通过使用ROR迁移来增加此限制。谢谢,沙湾 最佳答案 classYourMigration55enddefdownchange_column:users,:login,:string,:limit=>40endend 关于ruby-on-rails-rails迁移:HowtoincreasecolumndatatypesizebyusingRORmigration,我们在Sta