DB操作にRuby Sequel gemを使用しようとしています。
値の増減に行き詰まっています。
ドキュメントは、数字と記号を追加できるのは非常に奇妙に思えますが、これはうまくいくはずだと言っています。
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を与えるだけです...
これをどのように行うことができるかについて、誰かが光を当てることができますか?