4

我正在将数据库从 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))etc,它按预期工作。

使用 PG,它返回一个字符串而不是一个数字。

我已经检查了数据库并且数据类型是正确的。

to_d除了 cast or ,我还能做什么to_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
4

1 回答 1

3

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

请参阅:connection.select_value 仅使用 pg gem 在 postgres 中返回字符串

我并不特别赞同这一点,但正如俗话所说,它是“按预期工作”。

于 2013-09-12T19:43:02.813 回答