rake文件中的Sql查询未显示结果
我试图在rake任务中运行这个SQL查询,但它确实显示了任何结果。但是我尝试在Dbeaver中运行这个查询,它运行得非常好。第一个PUT只显示在终端中,第二个PUT不显示任何值。请帮我找到问题rake文件中的Sql查询未显示结果,sql,ruby-on-rails,postgresql,rake,Sql,Ruby On Rails,Postgresql,Rake,我试图在rake任务中运行这个SQL查询,但它确实显示了任何结果。但是我尝试在Dbeaver中运行这个查询,它运行得非常好。第一个PUT只显示在终端中,第二个PUT不显示任何值。请帮我找到问题 namespace :expense do desc "send emails" task send_reminder: :environment do sql = <<-SQL SELECT c.id as corporation_id ,
namespace :expense do
desc "send emails"
task send_reminder: :environment do
sql = <<-SQL
SELECT
c.id as corporation_id
, cs_i.id as issue_id
, MAX(i.id) as expense_id
, MAX(i."date") as expense_date
FROM companies c
JOIN expenses i on i.corporation_id = c.id
JOIN issues cs_i on i.issue_id = cs_i.id
WHERE c.amount > 0 and
cs_i.amount > 0 and
i."date" < (select (current_date at time zone 'UTC' - interval '1 week')) and i.amount_type = 0
GROUP BY c.id, cs_i.id
SQL
scope = Expense.connection.execute(sql)
puts "#{scope}"
scope.each do |expense|
puts "#{expense}"
end
end
end
如果您试图运行原始SQL,可能不应该使用connection.execute。有关方法,请参阅文档: 在此连接的上下文中执行SQL语句,并从连接适配器返回原始结果。注意:根据数据库连接器的不同,此方法返回的结果可能是手动内存管理的。考虑使用ExcQueQueR包装器。< /P> execute从连接适配器返回原始结果。例如,对于PostgreSQL,它是PG::Result对象 您可能也不想使用exec_查询,因为它还将返回某种原始结果 从我在代码中看到的情况来看,您可能希望使用。它执行查询并返回标准ActiveRecord对象: 名称空间:费用是多少 描述发送电子邮件 任务发送提醒::环境执行
sql=如果您试图运行原始sql,可能不应该使用connection.execute。有关方法,请参阅文档: 在此连接的上下文中执行SQL语句,并从连接适配器返回原始结果。注意:根据数据库连接器的不同,此方法返回的结果可能是手动内存管理的。考虑使用ExcQueQueR包装器。< /P> execute从连接适配器返回原始结果。例如,对于PostgreSQL,它是PG::Result对象 您可能也不想使用exec_查询,因为它还将返回某种原始结果 从我在代码中看到的情况来看,您可能希望使用。它执行查询并返回标准ActiveRecord对象: 名称空间:费用是多少 描述发送电子邮件 任务发送提醒::环境执行 sql=