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

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

ただいまの
回答率

90.61%

  • Ruby on Rails 4

    2406questions

    Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Rails コンソール(pry)でModel.allすると、そのモデルにあるカラム名と同名のメソッドが実行される

受付中

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 274

xaxaxaxa

score 2

こんにちは
件名のような症状が起き、困っております(・・;)

以下のようなモデルがあるとします

Userテーブル

  • name:string
  • age:integer
class User < ActiveRecord::Base
  def name
    puts "hoge"
  end
end

コンソールから
User.allをします。

すると、Userテーブルに5件ユーザがいた場合、

User Load (11.1ms)  SELECT `users`.* FROM `users`
hoge
hoge
hoge
hoge
hoge
=> [#<User:0x000ff3....

となり、なぜかカラム名の存在するメソッド名のメソッドが逐一実行されます

実際の動作には問題ないのですが、開発でコンソールを使うときに非常に困っておりますm(__)m

ちなみに、開発メンバーで私だけで、
同じgem,rails,rubyバージョンで、branch(作業ファイル)も同じです。
database.yml系も確認しました。

今日突然発症し、マックを再起動しても問題は継続します。
他のリポジトリでは発生しません(rubyバージョン等が違いますが。。)

環境は以下のとおりです
ruby 2.3.0
rails 4.2.6
pry (0.10.3)
pry-alias (0.0.1)
pry-byebug (3.3.0)
pry-doc (0.8.0)
pry-rails (0.3.4)

どなたかアドバイスいただけないでしょうかm(__)m
よろしくお願いいたします。

追加

一旦新しくcloneし直したのですが、同様でした(´・ω・`)

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

0

そもそも、どうしてこのようなUser#nameのメソッド定義をしたのでしょうか。

name:stringなテーブルのモデルである以上、nameメソッドはモデルの値の取得用メソッドとして存在します。そこを自前のメソッドで上書きしてしまうと、nameの値が取れないモデルになってしまいます。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/11 10:05

    ありがとうございます。
    理由があって、カラムがNULLのときに情報をセットするラッパー用のメソッドが必要でした。
    私が参加した時には既にあったコードなので、更に詳しい理由はわかりません。

    そして、なぜ私だけこのメソッドがコンソールでSELECTしただけで実行されるのかが謎になっております。

    よろしくお願いいたします。

    キャンセル

0

pry (0.10.3)
pry-alias (0.0.1)
pry-byebug (3.3.0)
pry-doc (0.8.0)
pry-rails (0.3.4)


ここらへんのgemは使用したことがないので詳しいことはわかりませんが、Railsが参照しているgemのディレクトリが他の開発者さんと違うことによって質問者さんだけに起こってしまっているということはないですか?

今日突然発症し、マックを再起動しても問題は継続します。


とのことですが突然発症する前にbundle installやbundle update等のコマンドを実行した覚えがあれば
そこが怪しいかもしれないですね

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/25 11:55

    ありがとうございます。

    ディレクトリは違いますが、他メンバーと同じくほとんどルート直下になります。

    Bundle系のは操作はしてなかったはずですが、もう一度確認してみます。ありがとうございます。m(__)m

    キャンセル

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

  • ただいまの回答率 90.61%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Ruby on Rails 4

    2406questions

    Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。