天天看点

leveldb之使用笔记

1.levelDB 只能实现单点部署,但是以文件的方式存贮数据,所以性能方面就会比其他的高相关链接

2.官网地址

3.golang leveldb client 地址

使用案例

1. 安装,要求 go版本>=1.4.

go get github.com/syndtr/goleveldb/leveldb
           

2 使用

创建数据库,一个路径就是一个数据库

package main
 import(
    "github.com/syndtr/goleveldb/leveldb"
    "fmt"
)
db, err := leveldb.OpenFile("path/to/db", nil)
if err!=nil{
    fmt.println("create levedb database failed",err);
    return
}
fmt.println("%#v",db);
//defer db.Close() 建议设置成全局变量
           

获取对应的key的value

data, err := db.Get([]byte("key"), nil)
           

设置或者修改key的value

err = db.Put([]byte("key"), []byte("value"), nil)
           

删除对应key的value

err = db.Delete([]byte("key"), nil)
           

遍历

iter := db.NewIterator(nil, nil)
for iter.Next() {
    key := iter.Key()
    value := iter.Value()
    ...
}
iter.Release()
err = iter.Error()
           
iter := db.NewIterator(nil, nil)
for ok := iter.Seek(key); ok; ok = iter.Next() {
    // Use key/value.
    ...
}
iter.Release()
err = iter.Error()
...
           
iter := db.NewIterator(&util.Range{Start: []byte("foo"), Limit: []byte("xoo")}, nil)
for iter.Next() {
    // Use key/value.
    ...
}
iter.Release()
err = iter.Error()
           
iter := db.NewIterator(util.BytesPrefix([]byte("foo-")), nil)
for iter.Next() {
    // Use key/value.
    ...
}
iter.Release()
err = iter.Error()
           

批量赋值

batch := new(leveldb.Batch)
batch.Put([]byte("foo"), []byte("value"))
batch.Put([]byte("bar"), []byte("another value"))
batch.Delete([]byte("baz"))
err = db.Write(batch, nil)
           

过滤

o := &opt.Options{
    Filter: filter.NewBloomFilter(),
}
db, err := leveldb.OpenFile("path/to/db", o)

defer db.Close()
           

基本上就这些了,只是简单地写了一下:)