iOS 轻量级的数据库leveldb
2015-12-08 21:23
162 查看
轻量级的数据库leveldb https://github.com/google/leveldb
一:在iOS下编译leveldb
终端:
1: git clone https://github.com/google/leveldb.git
2: 进入根目录
cd leveldb-master
3: 编译:
CXXFLAGS=-stdlib=libc++ make PLATFORM=IOS
编译完成之后,在当前目录里会生成 libleveldb.a , 支持全部模拟器与真机;
头文件在 include 目录下
二:引用库
leveldb是c++的;使用的时候需要oc的.m文件修改为.mm文件;
将编译好的库以group的形式导入到xcode工程;
使用oc的方式引用
#import "db.h"
#import "options.h"
#import "write_batch.h"
这时会出现xxx.h找不到的错误;
直接修改include 目录下的头文件;
把出错的头文件部分做如下修改
这种#include "leveldb/xx.h" 改为#include "xx.h"
三:test
参考:http://www.tanhao.me/pieces/1397.html/
http://www.cnblogs.com/haippy/archive/2011/12/04/2276064.html
一:在iOS下编译leveldb
终端:
1: git clone https://github.com/google/leveldb.git
2: 进入根目录
cd leveldb-master
3: 编译:
CXXFLAGS=-stdlib=libc++ make PLATFORM=IOS
编译完成之后,在当前目录里会生成 libleveldb.a , 支持全部模拟器与真机;
头文件在 include 目录下
二:引用库
leveldb是c++的;使用的时候需要oc的.m文件修改为.mm文件;
将编译好的库以group的形式导入到xcode工程;
使用oc的方式引用
#import "db.h"
#import "options.h"
#import "write_batch.h"
这时会出现xxx.h找不到的错误;
直接修改include 目录下的头文件;
把出错的头文件部分做如下修改
这种#include "leveldb/xx.h" 改为#include "xx.h"
三:test
#include <iostream> #include <string> #include <assert.h> #include "leveldb/db.h" using namespace std; int main(void) { leveldb::DB *db; leveldb::Options options; options.create_if_missing = true; // open leveldb::Status status = leveldb::DB::Open(options,"/tmp/testdb", &db); assert(status.ok()); string key = "name"; string value = "chenqi"; // write status = db->Put(leveldb::WriteOptions(), key, value); assert(status.ok()); // read status = db->Get(leveldb::ReadOptions(), key, &value); assert(status.ok()); cout<<value<<endl; // delete status = db->Delete(leveldb::WriteOptions(), key); assert(status.ok()); status = db->Get(leveldb::ReadOptions(),key, &value); if(!status.ok()) { cerr<<key<<" "<<status.ToString()<<endl; } else { cout<<key<<"==="<<value<<endl; } // close delete db; return 0; }
参考:http://www.tanhao.me/pieces/1397.html/
http://www.cnblogs.com/haippy/archive/2011/12/04/2276064.html
相关文章推荐
- mysql navcate longblob 查询结果导出倒入
- Oracle 中使用tkprof来查看比较delete,truncate,drop
- 运用.NIT将数据存入数据库、读取数据库(运用封装)陈老师作业
- mysql命令行连接查询
- MongoDB使用小结:一些常用操作分享
- 北大SQL数据库视频课程笔记
- SQL学习笔记(6)之DCL语句和事务
- sql 自定义搜索结果列名自定义
- mongodb操作
- SQLite初级操作
- 关于连接池的原理和实现方法
- Cannot add or update a child row: a foreign key constraint fails (`mysql`.`ordermx`, CONSTRAINT `kf
- oracle 数据导入导出命令
- mysql参考手册学习笔记
- MNIST手写数字数据库
- oracle迁移mysql数据库注意
- CentOS 6 安装Oracle11g
- [TwistedFate]数据库初级使用
- Sqlite3
- Mac平台重新设置MySQL的root密码