postgresql - Squeel 请求和 Heroku,Postgres : Error using GROUP BY and ORDER

标签 postgresql heroku squeel

我正在使用 mysql 开发我的应用程序,但我正在使用 Heroku 来部署它并且被迫使用 PG。

我对以下声明有疑问:

<% current_user_savings = Saving.where{user_id == my{current_user}} %>      

<% @latest_savings =  Saving.where{product_id.not_in(current_user_savings.select{product_id})}.group{product_id} %>

所以它在我的电脑上工作但是当部署到 heroku 时我有以下问题:

ActionView::Template::Error (PGError: ERROR:  column "savings.id" must appear in the GROUP      BY clause or be used in an aggregate function
LINE 1: SELECT "savings".* FROM "savings"  WHERE "savings"."product_...
SELECT "savings".* FROM "savings"  WHERE "savings"."product_id" NOT IN (SELECT "savings"."product_id" FROM "savings"  WHERE "savings"."user_id" = 1) GROUP BY "savings"."product_id"):

我真的不知道如何解决这个问题并让它在 heroku 上运行。

请求的 Gemfile : 来源 'https://rubygems.org'

ruby '1.9.3'
gem 'rails', '3.2.7'
gem 'compass_twitter_bootstrap', '2.0.3'
gem 'bcrypt-ruby', '3.0.1'
gem 'faker', '1.0.1'
gem 'will_paginate', '3.0.3'
gem 'bootstrap-will_paginate', '0.0.6'
gem 'omniauth-facebook', '1.4.0'
gem 'railroady'
gem 'devise', '2.1.2'
gem 'devise_invitable'
gem 'simple_form'
gem "mongoid", "~> 3.0.0"
gem 'thin'
gem 'best_in_place'
gem "jquery-fileupload-rails"
gem 'paperclip'
gem "squeel"
gem 'client_side_validations'
gem 'wicked'
gem 'koala'
gem 'aws-sdk'
gem 'bson_ext'


group :development, :test do
    gem 'sqlite3'
end
group :development, :test do
    gem 'annotate', '2.5.0'
end

group :test, :development do
    gem 'rspec-rails'
end

group :assets do
  gem 'sass-rails',   '~> 3.2.3'
  gem 'compass-rails', '1.0.3'
  gem 'coffee-rails', '~> 3.2.1'
  gem 'uglifier', '>= 1.0.3'
end

gem 'jquery-rails'
gem 'jquery-ui-rails'

group :test do
    gem 'capybara'
    gem 'factory_girl_rails'
end

group :production do
    gem 'pg', '0.12.2'
end 

最佳答案

我认为其中一些代码属于某个范围或至少属于您的 Controller 。但除此之外,你能发布你的 Gemfile 吗?

在我看来,最好的做法是在开发中使用相同的数据库和 ORM。你试过在本地运行PG吗?

看起来这里可能会发生一些事情让您很为难,首先让 PG 在您的开发机器上本地运行,然后更新您的 databases.yml 以使其一致。

其次,您是否也在使用 MongoBD?如果您不再使用 gem,可以将其从 bundle 中移除。

我稍微清理了你的 Gemfile 以使其更易于阅读,但我建议将 gem 分组以更好地代表 gem 在项目中的角色,我喜欢记录每个 gem 以便清楚确实如此,通常 Rails 应用程序倾向于以巨大的 Gemfile 结束,这使得选择别人的项目变得非常困难:

source 'https://rubygems.org'
ruby '1.9.3'

gem 'rails', '3.2.7'

gem 'compass_twitter_bootstrap', '2.0.3'
gem 'bcrypt-ruby', '3.0.1'
gem 'faker', '1.0.1'
gem 'will_paginate', '3.0.3'
gem 'bootstrap-will_paginate', '0.0.6'
gem 'omniauth-facebook', '1.4.0'
gem 'railroady'
gem 'devise', '2.1.2'
gem 'devise_invitable'
gem 'simple_form'
gem 'best_in_place'
gem "jquery-fileupload-rails"
gem 'paperclip'
gem "squeel"
gem 'client_side_validations'
gem 'wicked'
gem 'koala'
gem 'aws-sdk'

gem 'pg', '0.12.2'

gem 'jquery-rails'
gem 'jquery-ui-rails'

group :development, :test do
    gem 'annotate', '2.5.0'
    gem 'rspec-rails'
end

group :test do
    gem 'capybara'
    gem 'factory_girl_rails'
end

group :assets do
  gem 'sass-rails',   '~> 3.2.3'
  gem 'compass-rails', '1.0.3'
  gem 'coffee-rails', '~> 3.2.1'
  gem 'uglifier', '>= 1.0.3'
end

最后,查看您的 application.rb,并确保 ActiveRecord 可用,这似乎是必须的,但是看看,您可能有 require "rails/all" 在顶部附近的某个地方。

关于postgresql - Squeel 请求和 Heroku,Postgres : Error using GROUP BY and ORDER,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13145168/

相关文章:

ruby-on-rails-3 - 使用 Rails 和 Squeel 在 PostgreSQL 上请求

ruby-on-rails - 将 NOT 与 Squeel 一起使用

postgresql - 数据库部署和 Kubernetes 的重新创建策略会发生什么?

java - JPA 整数鉴别器值

Java + Postgresql : How to store Parent and List of all children in a HashMap<String, ArrayList <字符串>>

ruby-on-rails - 乘客使用比预期更多的 PostgreSQL 连接

sql - 插入 postgres 不工作

heroku - 无法从 GitHub 帐户断开 Heroku 应用程序

ruby-on-rails - Rails、Heroku 和子域。我的特殊情况可行吗?

sql - 优化困难查询(可能使用 squeel)