jjzjj

migration

全部标签

ruby-on-rails - Rails:PG::InsufficientPrivilege:错误:关系 schema_migrations 的权限被拒绝

我正在尝试在Rails中创建数据库。在Postgres中,我看到了开发和测试数据库,但是,我遇到了权限错误。我试过点击此链接,但对我不起作用。错误:PG::InsufficientPrivilege:错误:关系schema_migrations的权限被拒绝:SELECT"schema_migrations".*FROM"schema_migrations"Rails:permissiondeniedforrelationschema_migrationsdefault:&defaultadapter:postgresqlencoding:unicodepool:5host:localh

ruby-on-rails - Rails Migration 更改列以使用 Postgres 数组

我正在尝试更改数据库中的列,以便它可以使用Postgres数组数据类型。目前表列是字符串类型。我正在使用以下迁移来转换它:defchangechange_column:table,:dummy_column,:text,array:true,default:[]end但是我得到以下错误:bundleexecrakedb:migraterakeaborted!Anerrorhasoccurred,thisandalllatermigrationscanceled:PG::Error:ERROR:column"dummy_column"cannotbecastautomaticallyto

ruby-on-rails - 回滚所有 rails 迁移或删除表并修改迁移(从头开始)

我是Rails的新手,开始了一个我对我的模型和数据库模式不满意的项目。我想从头开始,但保留我所有的观点,Controller。执行此操作的最佳方法是什么?我想删除所有迁移和所有模型。在此过程之后不应留下不相关的文件(例如不再使用的迁移)。如果有帮助,我正在使用Rails3.1谢谢! 最佳答案 首先,将您的迁移回滚到版本0。rakedb:migrateVERSION=0然后您手动删除您的迁移和模型,保持Controller和View完好无损。 关于ruby-on-rails-回滚所有rai

ruby-on-rails - 如何使用其他方法扩展 ActiveRecord::Migration?

我正在创建一个Rubygem,并希望使用我自己的助手来扩展ActiveRecord::Migration以创建必要的列。(这类似于Devise在为其各种身份验证策略创建迁移时所做的事情。)我意识到我添加的功能本身非常微不足道,并且可能有更好/更有效的方法来做到这一点-我正在尝试将其作为学习经验而不是实际应用的东西。我只是想了解如何做一些像在Rails中添加新的迁移功能这样具有侵入性的事情。到目前为止,我已经成功构建到gem中并安装了,但是当我尝试运行如下迁移时:classCreatePosts...它没有说hideable没有定义。我研究了Devise完成此操作的方式,我不得不承认我有

ruby-on-rails - 如何配置额外的/不同的迁移文件夹

我和一位同事在共享某些模型的不同项目中工作。因此,我们通过git子模块共享模型。此外,我们还希望能够共享迁移:这样,我同事的迁移将在我项目的文件夹db/migrate/other_db中。如何配置Rails迁移以在这个额外的文件夹中运行迁移? 最佳答案 在您的配置文件中(config/application.rb用于所有环境或config/environments/$(environment).rb仅用于特定环境)添加此行:config.paths['db/migrate']+='db/migrate/other_db'如果你想改变

ruby - 如何禁用数据库 :schema:dump for migrations

我不希望Rails3在每次迁移时生成我的模式。如何正确禁用它?谢谢 最佳答案 对于仍在寻找在迁移后禁用数据库转储的方法的任何人,rails4中现在可以使用配置,可以像这样将其设置为false:config.active_record.dump_schema_after_migration=false会阻止它。此更改中已添加配置-https://github.com/rails/rails/pull/13948 关于ruby-如何禁用数据库:schema:dumpformigrations

ruby-on-rails - 类似 Rails 的数据库迁移?

是否有任何易于安装/使用(在unix上)的数据库迁移工具,例如RailsMigrations?我真的很喜欢这个想法,但是纯粹为了管理我的数据库迁移而安装ruby​​/rails似乎有些过分了。 最佳答案 只需使用ActiveRecord和一个简单的Rakefile。例如,如果您将迁移放在db/migrate目录中,并且有一个包含您的数据库配置的database.yml文件,那么这个简单的Rakefile应该可以工作:Rakefile:require'active_record'require'yaml'desc"Migratethe

ruby-on-rails - 未定义方法 `accept' 为 nil :NilClass on rake db:migrate

使用ruby​​-1.9.2和rails3.2.1。mysql2的版本是0.2.7。运行rakedb:migrate时出现错误:“nil:NilClass的未定义方法‘accept’:”跟踪包括:gems/activerecord-3.2.1/lib/active_record/connection_adapters/abstract/database_statements.rb:7:in`to_sql' 最佳答案 从以下位置更改您的Gemfile:gem'activerecord-mysql2-adapter'到:gem'mysq

ruby - 执行 rake db :migrate on Heroku 时出错

做的时候heroku运行rakedb:migrate所有迁移都已执行,最后我总是收到以下消息:/app/vendor/bundle/ruby/1.9.1/bin/rake:没有这样的文件或目录-pg_dump-i-s-x-O-f/app/db/structure.sqldan79p98fykovu我无法在Heroku上将pg_dump添加到PATH。如何处理? 最佳答案 问题在于,迁移完成后,rails会尝试转储新的structure.sql,但由于pg_dump不存在而失败。为已部署的应用程序生成新的structure.sql毫无

ruby-on-rails - ruby rails : adding columns to existing database

我收到一个错误:SQLite3::SQLException:nosuchcolumn:ideas.list_id:SELECT"ideas".*FROM"ideas"WHERE"ideas"."list_id"=2但是我加了t.integer:list_id到我的数据库迁移文件:classCreateIdeas这给了我这个:classCreateIdeas然后我输入rakedb:migrate知道为什么我会收到一条错误消息说没有专栏吗?我对RoR还是陌生的。我必须以其他方式添加一列吗?谢谢 最佳答案 正如Speransky所建议的,