1

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を与えるだけです...

これをどのように行うことができるかについて、誰かが光を当てることができますか?

4

1 に答える 1