【发布时间】:2013-06-19 19:15:50
【问题描述】:
我有一段代码在开发环境中运行良好,但在生产环境中引发错误。这里是:
venue.badges.where(:active => true).select([:title, :desc, :bonus]).each do |badge|
在处理 MySQL 本地数据库时,它会在生产环境中触发:
ActiveRecord::StatementInvalid (PG::Error: ERROR: syntax error at or near "desc"
: SELECT title, desc, bonus FROM "badges" WHERE "badges"."venue_id" = 22 AND "badges"."active" = 't'):
LINE 1: SELECT title, desc, bonus FROM "badges" WHERE "badges"."ven...
我真的不明白这里有什么问题。
【问题讨论】:
-
错误的一件事是您在一个数据库之上进行开发并在另一个数据库之上进行部署,这只是通往痛苦和痛苦的捷径。数据库之间有很多细微的差异,没有 ORM 可以保护您免受这些差异的影响。
标签: ruby-on-rails postgresql activerecord heroku