2013-07-31 3 views
1

Я пытаюсь использовать жемчужину Ruby Sequel для операций DB.Прирост приращения гейма

Я застреваю для увеличения и уменьшения значений.

В документе говорится, что это должно работать, хотя мне кажется очень странным, что я могу добавить число и символ.

2.0.0-p247 :019 > require 'sequel' 
=> true 
2.0.0-p247 :020 > s = Sequel.connect('sqlite://db.sqlite') 
=> #<Sequel::SQLite::Database: "sqlite://db.sqlite"> 
2.0.0-p247 :021 > s[:query_volume].update_sql(:queries => 3) 
=> "UPDATE `query_volume` SET `queries` = 3" 
2.0.0-p247 :022 > s[:query_volume].update_sql(:queries => :queries + 3) 
NoMethodError: undefined method `+' for :queries:Symbol 
    from (irb):21 
    from /Users/avandra/.rvm/rubies/ruby-2.0.0-p247/bin/irb:16:in `<main>' 

Но, как вы можете видеть, это дает неопределенный метод на символе запросов. Который любезно согласен с тем, почему это было странно для меня.

Я попытался с помощью фигурных скобок, но это дает другую ошибку:

2.0.0-p247 :023 > s[:query_volume].update_sql{:queries => :queries + 3} 
SyntaxError: (irb):23: syntax error, unexpected =>, expecting '}' 
s[:query_volume].update_sql{:queries => :queries + 3} 
            ^
     from /Users/avandra/.rvm/rubies/ruby-2.0.0-p247/bin/irb:16:in `<main>' 

И используя

2.0.0-p247 :033 > s[:query_volume].update_sql{queries = queries + 3} 
=> "UPDATE `query_volume` SET " 

просто дает плохо отформатированный SQL ...

Может кто-нибудь пролить некоторый свет как это можно сделать?

ответ

3

Вы должны использовать Sequel.expr для этого:

s[:query_volume].update_sql(:queries => Sequel.expr(3) + :queries)