mysql - 求和返回字符串,仅适用于 postgresql

标签 mysql ruby-on-rails-3 postgresql activerecord

我正在将数据库从 mysql 迁移到 postgres。按照 postgres 文档,迁移本身没问题。

现在,我正在修复我们特定的 mysql 查询。

在某种程度上,我们现在有这样的东西:

select(%(
  SUM(CASE WHEN income THEN value ELSE 0 END) AS rents,
  SUM(CASE WHEN not income THEN value ELSE 0 END) AS expenses
))

在 mysql 中,它是一个 sum(if(incomes, value, 0)) 等,它按预期工作。

对于 PG,它返回一个字符串而不是数字。

我已经检查过数据库,数据类型是正确的。

除了转换 to_dto_f 之外,我还能做什么?


编辑:完整的查询:

SELECT 
 SUM(CASE WHEN income THEN value ELSE 0 END) AS rents,
 SUM(CASE WHEN not income THEN value ELSE 0 END) AS expenses
 FROM "transactions"
 WHERE "transactions"."type" IN ('Transaction')
 AND "transactions"."user_id" = 1
 AND "transactions"."paid" = 't'
 AND (transactions.date between '2013-09-01' and '2013-09-30')
 LIMIT 1

最佳答案

据我所知,使用 .to_f.to_i 或任何答案 - Rails PostGres 适配器似乎坚持一切都是字符串,除非它是 ActiveRecord模型。

参见:connection.select_value only returns strings in postgres with pg gem

我不是特别赞成这种做法,但正如俗话说的那样,“按预期工作”。

关于mysql - 求和返回字符串,仅适用于 postgresql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18754007/

相关文章:

ruby - Postgres : Error using GROUP BY and ORDER (on heroku)

c++ - postgresql查询c++回调

PostgreSQL 删除触发器

mysql - 在MySQL中显示列中的数据行

php - 您的 SQL 语法有误;查看与您的 MySQL 服务器版本对应的手册,了解在 '?' 附近使用的正确语法

mysql - 根据多对多关系检索现有记录

php - MySQL定时器和删除函数

ruby-on-rails - 每当 cron 作业在 Rails 3 中不起作用时

ruby-on-rails - 非常基本的 Ruby 问题 (Rails for Zombies)

java - failed.org.hibernate.exception.JDBCConnectionException : Error calling Driver#connect with PostGres Hibernate