Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ruby-on-rails/53.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
rake文件中的Sql查询未显示结果_Sql_Ruby On Rails_Postgresql_Rake - Fatal编程技术网

rake文件中的Sql查询未显示结果

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 ,

我试图在rake任务中运行这个SQL查询,但它确实显示了任何结果。但是我尝试在Dbeaver中运行这个查询,它运行得非常好。第一个PUT只显示在终端中,第二个PUT不显示任何值。请帮我找到问题

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=