欢迎投稿

今日深度:

rocksdb使用

rocksdb使用


最近项目需要使用个key-value数据存储,在众多k-v数据库中,选择了rocksdb,原因只有一条,这货自称支持范围查询。

OK,git下载下来,编译,这里说一下,号称支持C++11所以对编译器的版本是有要求的,so,你得看看你的编译器是不是支持C++11.可以编译so和.a两种文件类型,这个跟其他的开源库一个套路,看看说明编译就行了,如果你发现由于Gtest的一些东西编译失败,可以试试编译动态的。

开始使用,我被API的名字小坑了一下,由于这哥给的文档有点粗糙,我就没细看,看到Ishead这种名字,居然反应的是设置他的前一个对象,呵呵,其实这个是判断他的key是不是以传入参数为开头的,对于范围查询,这个毛用都没有。

范围查询很简单,简单到令我发指,具体使用如下

rocksdb::Iterator* it = db->NewIterator(rocksdb::ReadOptions());

Slice sliceStart("cpu_host:172.28.20.123_serviec:redis_124");

std::string strEnd = "cpu_host:172.28.20.123_serviec:redis_135";

for (it->Seek(sliceStart);

it->Valid() && it->key().ToString() < strEnd;

it->Next()) {

std::string strInfo = it->key().ToString();

std::cout<

}

看懂了不,迭代的前面是找start,是slice类型的比对,后面end却成了string的比对了,好吧 这才是坑爹的关键啊。

www.htsjk.Com true http://www.htsjk.com/DB2/20257.html NewsArticle rocksdb使用 最近项目需要使用个key-value数据存储,在众多k-v数据库中,选择了rocksdb,原因只有一条,这货自称支持范围查询。 OK,git下载下来,编译,这里说一下,号称支持C++11所以对...
相关文章
    暂无相关文章
评论暂时关闭