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

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

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

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

Q&A

解決済

2回答

951閲覧

【Rails】バリデーションの最大文字数が正常に作動しない

katahik

総合スコア79

Ruby on Rails 6

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

0グッド

0クリップ

投稿2021/10/30 13:02

編集2021/10/30 22:35

前提・実現したいこと

Railsを使って開発を行っています。
モデルにvalidatesを設定して、バリデーションを行っていますが、最大文字数のバリデーションが正常に動きません
company.rb

validates :price, length: { maximum: 23 }, presence: true, numericality: true

このように記述して、フォームから
23文字(10000000000000000000000)入力した際にバリデーションに引っかかります。
ちなみに、
22文字(1000000000000000000000)もバリデーションに引っかかって、
21文字(100000000000000000000)にした場合にバリデーションが通りました。

Form.vue

<template> <main> <form> <fieldset> <legend>price</legend> <div class="form-row"> <b-form-input class="form-control" type="text"></b-form-input> </div> </fieldset> </form> </main> </template>

schema.rb

create_table "companies", id: :bigint, unsigned: true, options: "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4", force: :cascade do |t| ・ ・ ・ t.decimal "price", precision: 24, scale: 4 ・ ・ ・

params(23文字入力して、バリデーションに引っかかったとき)

Parameters: {"price"=>"10000000000000000000000"}

パラメータをみたときに文字列になっていたので、controllerのパラメータを受け取るところで、v[:price] = v[:price].to_i としましたが、やはり、バリデーションに失敗しました。

def create_company_params params.require(:company).permit( ).tap do |v| v[:price] = v[:price].to_i end end

なぜバリデーションの最大文字数が、モデルに設定したものと差異があるのか、わかりません。

みなさまのお知恵をお貸しいただければと思います。

環境

Ruby 2.6
Ruby on Rails 6.0

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

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

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

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

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

guest

回答2

0

自己解決

validates :price, numericality: { greater_than_or_equal_to: 0, less_than: 100000000000000000000, message:"は20文字以内の数字で入力してください"}

投稿2021/11/05 22:09

katahik

総合スコア79

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

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

0

データベースのデータ型は何でしょうか?

文字列としての制限以前に、10の23乗という巨大な値がデータベースに入らなかっただけ、ということはありませんか?

投稿2021/10/30 22:45

maisumakun

総合スコア146018

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

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

katahik

2021/10/30 23:00

@maisumakun いつもありがとうございます。 データ型はdecimal型で全体で24桁,小数点以下4桁を許容するようなデータ型を設定していますので、データ型については、問題ないと思っています。
katahik

2021/10/30 23:02

また、バリデーションのmaximumの値を大きくすれば、その大きくした分だけ入力できるようになったので、バリデーションの問題だと思っています。
maisumakun

2021/10/30 23:07

> データ型はdecimal型で全体で24桁,小数点以下4桁を許容するようなデータ型 それでは小数点以上が20桁しかないのではないでしょうか?
katahik

2021/10/30 23:34

ご指摘の通り、20桁までしか入らないですね。 いま、データベースのデータ型とおり、バリデーションのmaximumを20文字にしたところ、20文字ではバリデーションに引っかかって、18文字で入力したところ、バリデーションが通りました。
katahik

2021/10/30 23:36

やはり、2文字分少ないときにバリデーションが通る現象が発現してしまいます。
maisumakun

2021/10/30 23:57

そもそも論として、数字に対して「文字列としての長さ」でバリデーションをかけたい意図がわからないです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問