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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

解決済

1回答

566閲覧

Railsのcreateでnilがセットされているはずなのに、0で登録される理由について

yoppy0066

総合スコア293

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

0グッド

0クリップ

投稿2018/02/26 05:29

params //=> { status => "null" } params_hoge = params.require(:hoge).permit(:status) Hoge.create(params_hoge)

みたいにすると、「insert into hoges (status) values(0)」みたいなSQLが実行されるのですが、テーブル構造的には、not null制約で、デフォルト値の設定もされていません。

また、モデルの設定でも特に指定はありません。なぜこのような挙動になるかわかりますでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

status カラムは integer なんですよね。

で,paramsstatus の値は "null" という 文字列 なんですよね?

そうすると,status カラムに代入した時点で 0 になります。整数化する必要があるからです。
Ruby では

rb

1"abc".to_i #=> 0

です。

試しに,

rb

1hoge = Hoge.new status: "teratail" 2p hoge.status

をやってみましょう。0 ですよね。

なので,問題の所在は,空であるべきはずがなぜか "null" という 文字列 だったところにあるのではないかと思います。

投稿2018/02/26 13:29

scivola

総合スコア2108

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

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

yoppy0066

2018/02/26 14:02

ありがとうございます。 Rails側では、起動時に describe(MySQLの場合)した結果を内部的に保持しているため、statusがINT型であると判定していると考えて大丈夫でしょうか?
scivola

2018/02/26 14:11

よく知りませんが,そんな感じだと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問