如何在Ruby on Rails中修改特定模式的局部实现?
- 内容介绍
- 文章标签
- 相关推荐
本文共计365个文字,预计阅读时间需要2分钟。
我尝试修改一行schema.rb文件,将t.string变为t.text,但无法直接通过该文件进行修改。因为当我使用rake db:migrate时,更改将恢复到之前的状态。我该如何更改该字符串类型?
编辑:如果我理解正确,那么我需要直接修改schema.rb文件,而不是通过迁移。
解决方案:可以直接在schema.rb文件中找到对应字段,将`t.string`替换为`t.text`。然后保存文件。这样,下次运行rake db:migrate时,数据库结构将反映这些更改。
我试图改变一行schema.rb(t.string必须变成t.text)但是我无法直接通过该文件更改它,因为当我使用rake db:migrate时,更改将恢复到之前的状态.我该如何更改该字符串?
编辑:如果我没有误解某些东西,我必须编辑db / migrate中的文件.在我的情况下是2010110801532_create_posts.rb,我究竟要把change_column放在哪里?
这是我的2010110801532_create_posts.rb
class CreatePosts < ActiveRecord::Migration def self.up create_table :posts do |t| t.string :nome t.string :titolo t.text :contenuto t.timestamps end end def self.down drop_table :posts end end 一步步:
首先,生成一个新的迁移:
./script/generate migration change_string_to_text
在生成的迁移文件nnnnnnnnnnn_change_string_to_text.rb中,您需要添加以下行:
change_column :table_name, :column_name, :text
然后执行rake migrate以将更改应用于数据库.
本文共计365个文字,预计阅读时间需要2分钟。
我尝试修改一行schema.rb文件,将t.string变为t.text,但无法直接通过该文件进行修改。因为当我使用rake db:migrate时,更改将恢复到之前的状态。我该如何更改该字符串类型?
编辑:如果我理解正确,那么我需要直接修改schema.rb文件,而不是通过迁移。
解决方案:可以直接在schema.rb文件中找到对应字段,将`t.string`替换为`t.text`。然后保存文件。这样,下次运行rake db:migrate时,数据库结构将反映这些更改。
我试图改变一行schema.rb(t.string必须变成t.text)但是我无法直接通过该文件更改它,因为当我使用rake db:migrate时,更改将恢复到之前的状态.我该如何更改该字符串?
编辑:如果我没有误解某些东西,我必须编辑db / migrate中的文件.在我的情况下是2010110801532_create_posts.rb,我究竟要把change_column放在哪里?
这是我的2010110801532_create_posts.rb
class CreatePosts < ActiveRecord::Migration def self.up create_table :posts do |t| t.string :nome t.string :titolo t.text :contenuto t.timestamps end end def self.down drop_table :posts end end 一步步:
首先,生成一个新的迁移:
./script/generate migration change_string_to_text
在生成的迁移文件nnnnnnnnnnn_change_string_to_text.rb中,您需要添加以下行:
change_column :table_name, :column_name, :text
然后执行rake migrate以将更改应用于数据库.

