0

我在使用 Cassandra Gem 从 Cassandra 读取数据时遇到问题......这是我的代码:

require 'cassandra'
@states = {}
@client = Cassandra.new('Logs', "10.1.1.11:9160")
@client.get_range(:PlaybackStates) do |ckey,bb|
    @states[bb["State"].to_sym] = key
end
pp @states

我明白了:

{:DrmInit=>"\x00\x00\x00(",
 :Buffering=>"\x00\x00\x00x",
 :PreBuffering=>"\x00\x00\x002",
 :Debug=>"\x00\x00\x016",
 :FullScreen=>"\x00\x00\x01\x90",
 :Seek=>"\x00\x00\x00\x96",
 :LoadManifest=>"\x00\x00\x00\x14",
 :Play=>"\x00\x00\x00d"}

这是我所期望的:

{:DrmInit=>[40],
 :Buffering=>[120],
 :PreBuffering=>[50],
 :Debug=>[310],
 :FullScreen=>[400],
 :Seek=>[150],
 :LoadManifest=>[20],
 :Play=>[100]}

我可以通过在代码中执行此操作来获得此结果:

require 'cassandra'
@states = {}
@client = Cassandra.new('Logs', "10.1.1.11:9160")
@client.get_range(:PlaybackStates) do |ckey,bb|
    @states[bb["State"].to_sym] = ckey.unpack("N*") # unpacking the string with N*
end
pp @states

我还得到了时间戳和日期字段的二进制表示......我做错了吗?为什么 GEM 不转换数据类型?

4

1 回答 1

1

Twitter 的 cassandra gem 目前不理解 UTF8 以外的数据类型。因此,它将本机整数和其他数据类型解释为字符串。

我建议改用 cassandra-cql gem。它完全支持将原生 Cassandra 数据类型映射到原生 Ruby 类型。

https://github.com/kreynolds/cassandra-cql

http://rubygems.org/gems/cassandra-cql

于 2013-01-29T22:42:29.883 回答