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<std::endl;

    }

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


你可能感兴趣的:(rocksdb使用)