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

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

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

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

Q&A

解決済

1回答

323閲覧

validation ついて

masayao816

総合スコア10

Ruby on Rails

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

0グッド

0クリップ

投稿2020/03/09 08:44

編集2020/03/09 10:52

validationをつけるためにこのように設定しました。

Ruby

1    class User < ApplicationRecord 2 3   validates:name, presence: true 4 5   validates:email, presence: true, uniqueness: true 6 7 end
 モデル    class CreateUsers < ActiveRecord::Migration[6.0]    def change       create_table :users do |t|       t.string :name        t.string :email       t.timestamps      end    end    end

ですが、、、カラム名 nameの方は機能しますが

     カラム名 emailの方は機能しません。

例えばターミナルで

Ruby

1   user1=User.new(name:"中身が空",email:"適当なメールアドレス") 2 3   user1.save

をすると false になりますが

Ruby

1  user2=User.new(name:"適当な名前",email:"中身が空") 2    3              または 4 5  user2=User.new(name:"適当な名前",email:"他のメールアドレスと被っている") 6 7  user2.save

の場合は true になってしまいます。

解決策はありますか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

書き方がルールに則っていないかとおもいます。
波カッコを外す。スペースを加える。関係ないけどインデントは半角スペース2つ。

Ruby

1class User < ApplicationRecord 2 validates :name, presence: true 3 validates :email, presence: true, uniqueness: true 4end

また公式のページを見ながら設定したほうが色々と幸せになれます。
RailsGuide:バリデーション


とりあえず実行してみました。

ruby

1rails new test-app 2rails model name:string email:string 3rails db:migrate 4#作成されたapp/models/user.rbに上記バリデーションを追加 5rails c 6
irb(main):001:0> user1 = User.new(name:'',email:'1@gmail.com') (0.8ms) SELECT sqlite_version(*) => #<User id: nil, name: "", email: "1@gmail.com", created_at: nil, updated_at: nil> irb(main):002:0> user1.save (0.1ms) begin transaction User Exists? (0.5ms) SELECT 1 AS one FROM "users" WHERE "users"."email" = ? LIMIT ? [["email", "1@gmail.com"], ["LIMIT", 1]] (0.0ms) rollback transaction => false irb(main):003:0> user2 = User.new(name:'aaaaa',email:'') => #<User id: nil, name: "aaaaa", email: "", created_at: nil, updated_at: nil> irb(main):004:0> user2.save (0.1ms) begin transaction User Exists? (0.2ms) SELECT 1 AS one FROM "users" WHERE "users"."email" = ? LIMIT ? [["email", ""], ["LIMIT", 1]] (0.1ms) rollback transaction => false irb(main):005:0> user1 = User.new(name:'あああ',email:'1@gmail.com') => #<User id: nil, name: "あああ", email: "1@gmail.com", created_at: nil, updated_at: nil> irb(main):006:0> user1.save (0.1ms) begin transaction User Exists? (0.1ms) SELECT 1 AS one FROM "users" WHERE "users"."email" = ? LIMIT ? [["email", "1@gmail.com"], ["LIMIT", 1]] User Create (1.0ms) INSERT INTO "users" ("name", "email", "created_at", "updated_at") VALUES (?, ?, ?, ?) [["name", "あああ"], ["email", "1@gmail.com"], ["created_a "2020-03-09 11:46:44.041319"], ["updated_at", "2020-03-09 11:46:44.041319"]] (0.9ms) commit transaction => true irb(main):007:0> user1 = User.new(name:'iii',email:'1@gmail.com') => #<User id: nil, name: "iii", email: "1@gmail.com", created_at: nil, updated_at: nil> irb(main):008:0> user1.save (0.1ms) begin transaction User Exists? (0.2ms) SELECT 1 AS one FROM "users" WHERE "users"."email" = ? LIMIT ? [["email", "1@gmail.com"], ["LIMIT", 1]] (0.0ms) rollback transaction => false

イメージ説明

期待する動きとなっているので、バリデーション自体は問題ないかと思います。

投稿2020/03/09 09:30

編集2020/03/09 11:55
no1knows

総合スコア3365

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

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

masayao816

2020/03/09 09:40

ありがとうございます。 その通りやってみたのですがうまくいきませんでした、、、、
no1knows

2020/03/09 09:41 編集

タイポとかの可能性はありませんか? > user2=User.new(name:"適当な名前",eamil:"他のメールアドレスと被っている") eamilではなくemail
masayao816

2020/03/09 09:45

すいません。それはうち間違えました。ターミナルの時はスペルミスはないんですけど うまくいかないです、、。
no1knows

2020/03/09 09:47

controllerのソースを開示いただけますか? 質問を編集して追記して下さい。(コードはcodeタグを使って下さい。)
masayao816

2020/03/09 10:18

controllerはまだ作成していません。 ページを作成する前に validationを設定しようと思ったのですが、、
no1knows

2020/03/09 12:07

こちらで実行したところ期待通りの動作になったので、タイポの可能性が高いような気がします。 ご提示頂いたファイルのみで実行できるので、僕のレベルではサポートが難しいです。 一応、切り分けとして下記を実行いただくとなにかわかるかもしれません。 1.Rails Consoleでご提示させていただいた同じコードをコピペで実行して動作確認をする。 2.もし余裕があれば、上記の「とりあえず実行してみました」で新しいアプリを作成してみて確認いただくと良いかもしれません。
masayao816

2020/03/09 12:24

本当に協力していただいてもらって ありがとうございました。先ほどやってみたところうまくいきました。????‍♂️ 本当に感謝です。お手数お掛けしました????‍♂️
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問