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

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

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

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

Q&A

解決済

2回答

2366閲覧

rails: アソシエーションのモデルで関連modelのidをnilで生成したい

TakakiKuwabara

総合スコア38

Ruby on Rails

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

0グッド

0クリップ

投稿2017/02/01 13:35

Railsの勉強で表題の件ができずに困っております。
ご教授いただけないでしょうか。

AuthenticationモデルとAuthenticationLogモデルを下記の通りに関連付けを行い、
AuthenticationLogモデルのauthentication_idをnilで生成する方法はないでしょうか。

AuthenticationLog.create(:key => "testkey", :authentication_id => nil)
でロールバックが発生して困っております。

①Authenticationモデルについて

class CreateAuthentications < ActiveRecord::Migration[5.0] def change create_table: authentications do |t| t.string :key t.timestamps end end end class Authentication < ApplicationRecord has_many :authentication_logs end

②AuthenticationLogモデルについて

class CreateAuthenticationLogs < ActiveRecord::Migration[5.0] def change create_table: authentication_logs do |t| t.string :key t.integer :authentication_id => こいつをnilでcreateしたい t.timestamps end end end class AuthenticationLog < ApplicationRecord belongs_to :authentication end

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

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

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

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

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

guest

回答2

0

自己解決

すいません。自己解決しました。
create、もしくはsave時のバリデートで弾かれているようでした。

@a = AuthenticationLog.new(:key => @key)
@a.save(:validate => false)

上記により、バリデートを無効化することで実行ができました。
セキュリティ上どうなのかと思うので、色々実験してみて模索したいと思います。

投稿2017/02/05 00:05

TakakiKuwabara

総合スコア38

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

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

0

次のようにすれば、メモリ上には生成できます。

a = AuthenticationLog.new(key: "xx") => #<AuthenticationLog id: nil, key: "xx", authentication_id: nil, created_at: nil, updated_at: nil>

さらに、つぎのようにして保存もできます。

a.save(validate:false) (0.1ms) begin transaction SQL (0.4ms) INSERT INTO "authentication_logs" ("key", "created_at", "updated_at") VALUES (?, ?, ?) [["key", "xx"], ["created_at", 2017-02-01 14:06:52 UTC], ["updated_at", 2017-02-01 14:06:52 UTC]] (2.8ms) commit transaction => true

AuthenticationLog.all で確認してみます。

AuthenticationLog.all AuthenticationLog Load (0.2ms) SELECT "authentication_logs".* FROM "authentication_logs" => #<ActiveRecord::Relation [#<AuthenticationLog id: 1, key: "xx", authentication_id: 1, created_at: "2017-02-01 14:03:37", updated_at: "2017-02-01 14:03:37">, #<AuthenticationLog id: 2, key: "xx", authentication_id: nil, created_at: "2017-02-01 14:06:52", updated_at: "2017-02-01 14:06:52">]>

投稿2017/02/01 14:11

katoy

総合スコア22324

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

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

TakakiKuwabara

2017/02/04 14:26

こちらで確認してみましたが、うまくいきませんでした。 belong_to, has_manyは記述して実行されましたか? ◇ソース begin ActiveRecord::Base.transaction do # 認証ログを生成 @aa = AuthenticationLog.new(:key => @key) p @aa.save end rescue => e # ユーザー認証ログの生成 @error = {:error_class => self.class.to_s, :message => e.message} error_log end end ◇コンソール結果 Rendering api/v1/user/authentication/index.json.jbuilder Rendered api/v1/user/authentication/index.json.jbuilder (0.6ms) Started POST "/api/v1/user/authentication.json" for 127.0.0.1 at 2017-02-04 23:23:06 +0900 Processing by Api::V1::User::AuthenticationController#index as JSON (0.1ms) begin transaction false (0.1ms) commit transaction Completed 200 OK in 41ms (Views: 13.4ms | ActiveRecord: 3.1ms)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問