PG :: InvalidTextRepresentation:ERROR:整数的输入语法无效

时间:2016-05-06 11:27:09

标签: ruby-on-rails postgresql prepared-statement psql

我正在使用rails上的预准备语句进行“IN”查询。我收到PG :: InvalidTextRepresentation错误。

代码:

def mark_ineligible(match_ids)
  ids = match_ids.join(", ")
  result = epr("mark_matches_as_ineligible",
               "UPDATE matches SET is_eligibile=false WHERE id IN ( $1 )",
               [ids])
end

def epr(statementname, statement, params)
  connection = ActiveRecord::Base.connection.raw_connection
  begin
    result = connection.exec_prepared(statementname, params)
    return result
  rescue PG::InvalidSqlStatementName => e
    begin
      connection.prepare(statementname, statement)
    rescue PG::DuplicatePstatement => e
      # ignore since the prepared statement already exists
    end
    result = connection.exec_prepared(statementname, params)
    return result
  end
end

尝试使用以下方法调用此方法:

match_ids = [42, 43]
mark_ineligible match_ids
PG::InvalidTextRepresentation: ERROR:  invalid input syntax for integer: "42, 43"

    from (irb):24:in `exec_prepared'
    from (irb):24:in `rescue in epr'
    from (irb):15:in `epr'
    from (irb):8:in `mark_ineligible'
    from (irb):35

请在这里帮忙。我想知道为什么我会收到这些错误以及如何修复它。

谢谢,

1 个答案:

答案 0 :(得分:0)

mark_ineligible应如下所示:

def mark_ineligible(match_ids)
    result = epr("mark_matches_as_ineligible",
           "UPDATE matches SET is_eligibile=false WHERE id IN ( $1 )", match_ids)
end

当你调用mark_ineligible时,传递一个数组作为参数:

mark_ineligible(match_ids)  #=>match_ids = [42,43]