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

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

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

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

Q&A

解決済

1回答

2817閲覧

【Ruby on Rails】アクションクエリのデバッグを行いたい

pecchan

総合スコア555

Ruby on Rails

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

0グッド

1クリップ

投稿2018/01/04 21:09

Ruby on Rails初心者です。

update()実行時、発行されたSQLを確認したいです。

選択クエリは以下のようにデバッグ出来るようなので、

ruby

1User.all().to_sql()

以下のように同じにしたのですが、エラーになりました。

ruby

1User.update(パラメータ).to_sql()

エラーメッセージ
「undefined method `to_sql' for true:TrueClass Did you mean? to_s」

アクションクエリを確認する場合は、違う方法でしょうか?

教えていただけないでしょうか?

宜しくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんにちは。

同様の質問が、stackoverflow にあったので挙げておきます。

to_sql not working on update_attributes or .save

これの回答に

These methods both return a boolean. You can't invoke to_sql on a boolean.

とあるように、updatecreateは、booleanを返すので、to_sql を使うことは
できませんが、上記の回答および回答にあるリンク先の別の質問

Log every SQL query to database in Rails

を見ると、以下のような特異メソッドをDBへのコネクションに追加すると、
(実際に動かして確認していませんが、)SQLをファイルに出力することを
実現できそうです。

ruby

1connection = ActiveRecord::Base.connection 2class << connection 3 alias :original_exec :execute 4 def execute(sql, *name) 5 # try to log sql command but ignore any errors that occur in this block 6 # we log before executing, in case the execution raises an error 7 begin 8 file = File.open(RAILS_ROOT + "/log/sql.txt",'a'){|f| f.puts Time.now.to_s+": "+sql} 9 rescue Exception => e 10 ; 11 end 12 # execute original statement 13 original_exec(sql, *name) 14 end 15end

以上参考になれば幸いです。

投稿2018/01/04 21:43

編集2018/01/04 22:39
jun68ykt

総合スコア9058

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

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

pecchan

2018/01/04 22:01

有難う御座います。 なるほど、出来ない理由が分かりました。 参考情報まで有難う御座います!!
jun68ykt

2018/01/04 22:10

疑問が解決されたようでよかったです!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問