rocksdb使用
来源:互联网 发布:对数据库安全性的认识 编辑:程序博客网 时间:2024/06/01 15:38
最近项目需要使用个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的比对了,好吧 这才是坑爹的关键啊。
- rocksdb使用
- rocksdb
- RocksDB
- RocksDB在cygwin编译与使用
- 编译安装mongo使用rocksdb引擎
- CentOS 6 使用rocksdb遇到的问题以及解决办法
- RocksDB整理
- RocksDB 介绍
- RocksDB译文之一 -- RocksDB简介
- rocksdb:DestroyDB函数
- rocksdb 编译安装 日志
- 编译level db rocksdb
- RocksDB上锁机制
- Rocksdb 数据库--MANIFEST文件
- Rocksdb数据库---levle compaction
- Rocksdb Merge Operator
- rocksdb table formats
- Editing Rocksdb BlockBasedTable Format
- 浙江大学PAT_乙级_1005. 继续(3n+1)猜想 (25)
- UVa 257 - Palinwords
- 再学JavaScript-第五课-深入理解面向对象
- C++拷贝构造函数
- 深入Qt 学习 -- 反射机制
- rocksdb使用
- NSString和NSMutableString
- uva 1592
- 数独游戏
- Java语法小记
- Android View绘制及实践
- 第K短路
- UI的优化之ToolTip控件的使用
- Dialogue System for Unity文档中文对照版(简雨原创翻译)第一篇(我们开始仙剑demo的剧情)