Ruby将SQL查询字符串解析为哈希

时间:2015-05-06 17:53:12

标签: sql ruby-on-rails ruby parsing

我正在尝试将SQL查询字符串解析为哈希。例: field = value AND field2 = value2变为{ field: 'value', field2: 'value2' }

我尝试了Rack::Utils.parse,它对于URL参数很有用,但不适用于SQL查询字符串。

我最初的想法是按AND, OR等分割,然后递归使用Rack::Utils.parse

我原本以为在Rails中会有一种直截了当的方式,但我还没有找到任何东西。有没有人以前完成过这个?

提前致谢。

1 个答案:

答案 0 :(得分:1)

sql_query = 'field = value AND field2 = value2 OR field3 = value3'

def hash_for sql_query
  parts = sql_query.split /(and|or)/i
  parts.map do | p | 
    fv = p.split('=').map &:strip
    { fv[0].to_sym => fv[1] }
  end
end