お世話になってます。
現在、自信のポートフォリオサイトを作成しております。
その内容は、就職用に個性を見つけるというもので、こちらが用意した質問にユーザーが回答していくというものなのですが、その回答の初期値を設定しようとしてもエラーがでてうまく反映されません。
具体的にはユーザーが質問の回答をまだ入力していない時は「未入力」という文字を表示したいです。
ですが、モデルを作成するさいdefaultについての記載をせずにmigrateしてしまったため、回答テーブルのdefaultカラムは全てNULLとなってしまっています。
それを変えようと
rails g migration change_default_to_user
とマイグレーションファイルを作成し
change_column :users, :answer, :text, default: '未入力'
というようにコーディングしたのですがrails db:migrateの結果はこのようになりました。
== 20190226074237 AddDefaultToUser: migrating ================================= -- change_column(:users, :answer, :text, {:default=>"未入力"}) rails aborted! StandardError: An error has occurred, all later migrations canceled: Mysql2::Error: BLOB/TEXT column 'answer' can't have a default value: ALTER TABLE `users` CHANGE `answer` `answer` text DEFAULT '未入力' /home/ec2-user/environment/portfolio/db/migrate/20190226074237_add_default_to_user.rb:3:in `change' /home/ec2-user/environment/portfolio/bin/rails:9:in `require' /home/ec2-user/environment/portfolio/bin/rails:9:in `<top (required)>' /home/ec2-user/environment/portfolio/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Caused by: ActiveRecord::StatementInvalid: Mysql2::Error: BLOB/TEXT column 'answer' can't have a default value: ALTER TABLE `users` CHANGE `answer` `answer` text DEFAULT '未入力' /home/ec2-user/environment/portfolio/db/migrate/20190226074237_add_default_to_user.rb:3:in `change' /home/ec2-user/environment/portfolio/bin/rails:9:in `require' /home/ec2-user/environment/portfolio/bin/rails:9:in `<top (required)>' /home/ec2-user/environment/portfolio/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Caused by: Mysql2::Error: BLOB/TEXT column 'answer' can't have a default value /home/ec2-user/environment/portfolio/db/migrate/20190226074237_add_default_to_user.rb:3:in `change' /home/ec2-user/environment/portfolio/bin/rails:9:in `require' /home/ec2-user/environment/portfolio/bin/rails:9:in `<top (required)>' /home/ec2-user/environment/portfolio/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Tasks: TOP => db:migrate (See full trace by running task with --trace)
このエラーから、「answerはdefaultを持てない=NULLになっているから」と考え
change_column :users, :answer, :text, :null => false , default: '未入力'
とかいても結果は同じでした。
やはりデフォルトは最初から設定しないと後からは変更できないのでしょうか?
ご回答よろしくお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。