我正在将数据库从 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_d
或 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
最佳答案
据我所知,使用 .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/