質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1891閲覧

Rails カラムのデフォルト値について

SpaceRange

総合スコア24

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

1クリップ

投稿2019/02/26 09:29

お世話になってます。

現在、自信のポートフォリオサイトを作成しております。
その内容は、就職用に個性を見つけるというもので、こちらが用意した質問にユーザーが回答していくというものなのですが、その回答の初期値を設定しようとしてもエラーがでてうまく反映されません。

具体的にはユーザーが質問の回答をまだ入力していない時は「未入力」という文字を表示したいです。
ですが、モデルを作成するさい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: '未入力'

とかいても結果は同じでした。
やはりデフォルトは最初から設定しないと後からは変更できないのでしょうか?
ご回答よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

エラーメッセージに書いてあるとおり、MySQLではTEXT型の列にはデフォルト指定ができません(MySQL 5.6のリファレンス)。

255文字で足りるのであれば、VARCHAR(Railsでは:string)にすれば、デフォルト値が適用可能です。

投稿2019/02/26 13:01

maisumakun

総合スコア145121

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問