0

Railsの「ジャンル」列で一意の値を取得しようとしています。コメントアウトされたセクションは localhost で機能しますが、本番環境では PG Error: ActiveRecord::StatementInvalid (PGError: ERROR: for SELECT DISTINCT, ORDER BY Expressions must appear in select list ) が発生します。これを見つけましが、適用方法がよくわかりません特定の列で一意の値を探しているので、私の場合はそれです。

    @iosapps = Iosapp.where(:user_id => me.id, :payment => 'free', :updated_at => days_ago..present ).order('updated_at DESC')
    @categories = Iosapp.order('updated_at DESC')
.where(:user_id => me.id)
.where(:payment => 'free')
.where(:updated_at => days_ago..present)
.select("distinct genre")

ビューのエラー:

2013-05-16T03:32:05.772029+00:00 app[web.2]:     51:             Category:
2013-05-16T03:32:05.772029+00:00 app[web.2]:     52:             <select id = 'category'>
2013-05-16T03:32:05.772029+00:00 app[web.2]:     53:                 <option value = "All">All</option>
2013-05-16T03:32:05.772029+00:00 app[web.2]:     54:                 <% @categories.each do |genre| %>
2013-05-16T03:32:05.772029+00:00 app[web.2]:     55:                     <option value = "<%= genre.genre %>"><%= genre.genre %></option>
2013-05-16T03:32:05.772318+00:00 app[web.2]:     56:                 <% end %>
2013-05-16T03:32:05.772318+00:00 app[web.2]:     57:             </select>
2013-05-16T03:32:05.772318+00:00 app[web.2]:   app/views/iosapps/test.html.erb:54:in `_app_views_iosapps_test_html_erb__2525281577349110042_49052520'
4

1 に答える 1

0

たぶん試してみてください

Iosapp.order('updated_at DESC')
  .where(:user_id => me.id)
  .where(:payment => 'free')
  .where(:updated_at => days_ago..present)
  .select("distinct genre")

また、本番環境で使用しているのと同じデータベースに対して開発することをお勧めします

于 2013-05-16T03:05:55.350 に答える