GolangNote

Golang笔记

golang leveldb 遍历数据

Permalink

golang leveldb 遍历数据

Go: leveldb 遍历
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
package main

import (
    "fmt"
    "github.com/syndtr/goleveldb/leveldb"
)

func main() {
    db, err := leveldb.OpenFile("gossip.db", nil)
    if err != nil {
        fmt.Println(err)
        return
    }

    for i := 1; i < 10; i++ {
        err = db.Put([]byte(fmt.Sprintf("key-%d", i)), []byte(fmt.Sprintf("value-%d", i)), nil)
        if err != nil {
            fmt.Println(err)
            return
        }
    }

    iter := db.NewIterator(nil, nil)
    for iter.Next() {
        // Remember that the contents of the returned slice should not be modified, and
        // only valid until the next call to Next.
        key := iter.Key()
        value := iter.Value()
        fmt.Println(string(key), string(value))
    }
    iter.Release()
    err = iter.Error()
    if err != nil {
        fmt.Println(err)
        return
    }
    defer db.Close()
}

运行输出:

Bash: leveldb 遍历 输出
1
2
3
4
5
6
7
8
9
key-1 value-1
key-2 value-2
key-3 value-3
key-4 value-4
key-5 value-5
key-6 value-6
key-7 value-7
key-8 value-8
key-9 value-9

再举个栗子:

Go: leveldb 遍历
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
package main

import (
    "fmt"
    "github.com/syndtr/goleveldb/leveldb"
    "log"
)

func main() {
    db, err := leveldb.OpenFile("/tmp/foo.db", nil)
    if err != nil {
        log.Fatal("Yikes!")
    }
    defer db.Close()

    //  err = db.Put([]byte("fizz"), []byte("buzz"), nil)
    //  err = db.Put([]byte("fizz2"), []byte("buzz2"), nil)
    //  err = db.Put([]byte("fizz3"), []byte("buzz3"), nil)

    iter := db.NewIterator(nil, nil)
    for iter.Next() {
        key := iter.Key()
        value := iter.Value()
        fmt.Printf("key: %s | value: %s\n", key, value)
    }

    fmt.Println("\n")

    for ok := iter.Seek([]byte("fizz2")); ok; ok = iter.Next() {
        key := iter.Key()
        value := iter.Value()
        fmt.Printf("key: %s | value: %s\n", key, value)
    }

    fmt.Println("\n")

    for ok := iter.First(); ok; ok = iter.Next() {
        key := iter.Key()
        value := iter.Value()
        fmt.Printf("key: %s | value: %s\n", key, value)
    }

    iter.Release()
    err = iter.Error()
}

本文网址: https://golangnote.com/topic/79.html 转摘请注明来源

Related articles

golang共享数据用Mutex 或 Channel

在go 里,多线程对共享数据的操作一般要使用Mutex 或 Channel 来加锁或隔离通信。下面是一个使用Mutex 和 Channel 比较的例子。...

Golang http client 处理重定向网页

假设一个网址有多个重定向,A-B-C-D,使用 http.Client.Get 最后取得的内容是网址D的内容,我们该手动处理包含重定向的网址。...

Golang Web 程序生产环境独立部署示例

一个 web 应用通常是跑在一个前端代理,如 Nginx 后,这样可以方便的在同一个服务器部署多个应用。这里说的独立部署是指让 go web 程序直接暴露在外面,独占 443、80 端口(俗称裸跑)。这样做除了性能有些提高外,更重要的是部署方便。...

Golang sync.WaitGroup 的 Wait 超时处理

sync.WaitGroup 使用 `Add(1)`、`Done()`、`Wait()`组合来实现多协程等待,如果某一协程未能合理处理错误,导致无法退出,此时需要引入超时机制。下面是一种超时处理方法。...

golang snappy 的使用场合

google 自家的 snappy 压缩优点是非常高的速度和合理的压缩率。压缩率比 gzip 小,CPU 占用小。...

Golang 数据库 Bolt 碎片整理

Bolt 是一个优秀、纯 Go 实现、支持 ACID 事务的嵌入式 Key/Value 数据库。但在使用过程中会有很多空间碎片。一般数据库占用的空间是元数据空间的 1.5~4 倍。Bolt 没有内置的压缩功能,需要手动压缩。...

Write a Comment to "golang leveldb 遍历数据"

Submit Comment Login
Based on Golang + fastHTTP + sdb | go1.20 Processed in 0ms