カテゴリ: Rails 更新日: 2026/01/26

Railsバリデーション入門:presence / uniqueness / length の基本と使い分け【保存版】

Railsバリデーション入門:presence/uniqueness/length の基本と使い分け【保存版】
Railsバリデーション入門:presence/uniqueness/length の基本と使い分け【保存版】

先生と生徒の会話形式で理解しよう

生徒

「Railsで入力チェックって、どうやってやるんですか?空欄を防いだり、同じデータを登録できないようにしたいです」

先生

「Railsではバリデーションという仕組みを使って、保存前にデータを確認できます」

生徒

「難しそうですが、初心者でも使えますか?」

先生

「大丈夫です。presence・uniqueness・lengthの3つを覚えるだけで、基本的な入力チェックはできます」

1. Railsのバリデーションとは何か

1. Railsのバリデーションとは何か
1. Railsのバリデーションとは何か

Railsのバリデーションとは、データベースに保存する前に「このデータは正しいか」を確認する仕組みです。たとえば、名前が空のまま保存されると、あとで誰のデータかわからなくなります。そこでRailsでは、モデルにルールを書いておくことで、正しくないデータを保存させないようにできます。

これは現実世界でいうと、申込書に「名前は必ず書いてください」「電話番号は10文字以上必要です」と注意書きがあるのと同じです。Railsはその注意書きを自動でチェックしてくれる便利な存在です。

2. presenceバリデーション:空欄を防ぐ基本ルール

2. presenceバリデーション:空欄を防ぐ基本ルール
2. presenceバリデーション:空欄を防ぐ基本ルール

presenceは「値が入っているか」を確認するバリデーションです。Rails初心者が最初に覚えるべき、とても重要なルールです。空文字やnilの場合、保存されません。


class User < ApplicationRecord
  validates :name, presence: true
end

この設定をすると、nameが空のままではUserを保存できません。ログイン名、メールアドレス、タイトルなど「必須項目」に必ず使われます。

3. uniquenessバリデーション:同じ値を重複させない

3. uniquenessバリデーション:同じ値を重複させない
3. uniquenessバリデーション:同じ値を重複させない

uniquenessは「同じ値がすでに存在していないか」を確認するバリデーションです。ユーザー名やメールアドレスなど、重複すると困るデータで使います。


class User < ApplicationRecord
  validates :email, uniqueness: true
end

これにより、同じメールアドレスを持つユーザーは登録できなくなります。SNSや会員登録サイトでは必須の設定です。

実務では、データベース側にもユニークインデックスを設定すると、より安全になります。

4. lengthバリデーション:文字数を制限する

4. lengthバリデーション:文字数を制限する
4. lengthバリデーション:文字数を制限する

lengthは、文字数の最小・最大を決めるバリデーションです。短すぎるパスワードや、長すぎるコメントを防ぐために使います。


class Article < ApplicationRecord
  validates :title, length: { minimum: 5, maximum: 30 }
end

この例では、タイトルは5文字以上30文字以内でなければ保存できません。入力フォームの品質を保つために重要です。

5. バリデーションエラーはどう表示されるか

5. バリデーションエラーはどう表示されるか
5. バリデーションエラーはどう表示されるか

バリデーションに失敗すると、Railsは保存を中止し、エラーメッセージを自動で用意します。コントローラやビューから、その内容を確認できます。


user = User.new(name: "")
user.save
user.errors.full_messages

["Nameを入力してください"]

このように、人が読める日本語メッセージで理由を確認できるため、フォーム画面にもそのまま表示できます。

6. before_*コールバックで保存前に処理をする

6. before_*コールバックで保存前に処理をする
6. before_*コールバックで保存前に処理をする

コールバックとは、保存や更新の前後に自動で呼ばれる処理です。before_*は「〜する前」という意味で、保存前の準備によく使われます。


class User < ApplicationRecord
  before_save :normalize_email

  private

  def normalize_email
    self.email = email.downcase
  end
end

この例では、保存前にメールアドレスを小文字に変換しています。入力のゆらぎを防ぎ、uniquenessバリデーションと相性が良い使い方です。

7. バリデーションとコールバックの使い分け

7. バリデーションとコールバックの使い分け
7. バリデーションとコールバックの使い分け

「正しいかどうかを確認する」のがバリデーション、「データを整える」のがコールバックです。混同しがちですが、役割は明確に分かれています。

たとえば、空欄チェックや文字数制限はバリデーション、文字の変換や初期値設定はbefore_*コールバック、と覚えると理解しやすくなります。

8. 初心者がつまずきやすいポイント

8. 初心者がつまずきやすいポイント
8. 初心者がつまずきやすいポイント

Rails初心者がよく困るのは「保存できない理由がわからない」ことです。その場合は、errors.full_messagesを確認すると原因が見えます。

また、uniquenessはデータベースの状態に依存するため、開発中はテストデータを消してから確認すると理解しやすくなります。

カテゴリの一覧へ
新着記事
New1
Ruby
“すべてはオブジェクト”を体感!初心者向けRubyのオブジェクト指向入門【irbで学ぶ】
New2
Ruby
Rubyの標準入出力を完全ガイド!puts・print・pの違いとデバッグ活用法
New3
Ruby
Gemとは?RubyGemsとBundlerを初心者向けに完全解説!依存関係管理も図解でわかりやすく理解
New4
Ruby
Rubyの文字エンコーディング入門!UTF-8・マジックコメント・外部/内部エンコーディングを完全解説
人気記事
No.1
Java&Spring記事人気No1
Ruby
Rubyのreduceとinject入門!合計計算や集計を初心者向けに分かりやすく解説
No.2
Java&Spring記事人気No2
Ruby
Rubyの文字列エンコーディング完全ガイド!Encoding・force_encoding・encodeを初心者向け解説
No.3
Java&Spring記事人気No3
Ruby
Rubyの始め方ガイド:インストールから最初のHello Worldまで(Windows/Mac/Linux)
No.4
Java&Spring記事人気No4
データベース
PostgreSQLのWHERE句を徹底解説!初心者でもわかるSQLデータ抽出の基本
No.5
Java&Spring記事人気No5
Ruby
Rubyのfind/detect/find_indexを徹底解説!目的のデータを素早く探す方法
No.6
Java&Spring記事人気No6
Ruby
Rubyで比較演算子を完全解説!==・===・<=>・eql? の使い分け
No.7
Java&Spring記事人気No7
Ruby
Rubyのselect/reject/filterの使い方を完全解説!初心者向けの条件抽出レシピ
No.8
Java&Spring記事人気No8
データベース
PostgreSQLで順位付け!ROW_NUMBER関数の使い方を初心者向けに徹底解説