最近项目需要使用个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<<strInfo<<std::endl;
}
看懂了不,迭代的前面是找start,是slice类型的比对,后面end却成了string的比对了,好吧 这才是坑爹的关键啊。
原文地址:http://blog.csdn.net/q96456/article/details/45458641