golang框架如何与NoSQL数据库交互?

go 框架通过标准库和第三方框架,为与 nosql 数据库交互提供了强大的功能。这些框架包括:1. mongodb 库:mgo;2. redis 库:redigo;3. cassandra 库:gocql。这些框架提供了与 mongodb、

go 框架通过标准库和第三方框架,为与 nosql 数据库交互提供了强大的功能。这些框架包括:1. mongodb 库:mgo;2. redis 库:redigo;3. cassandra 库:gocql。这些框架提供了与 mongodb、redis 和 cassandra 数据库交互的 api,包括建立连接、执行查询、插入、更新和删除文档等操作。

golang框架如何与NoSQL数据库交互?

Go 框架与 NoSQL 数据库交互

NoSQL 数据库因其可扩展性、灵活性和大容量存储能力而在现代应用程序中越来越受欢迎。Go 语言通过其标准库和丰富的第三方框架提供了与 NoSQL 数据库交互的强大功能。

以下是如何使用 Go 框架与 NoSQL 数据库交互:

1. MongoDB

  • 库: [mgo](https://godoc.org/gopkg.in/mgo.v2)
package main

import (
    "context"
    "fmt"
    "log"
    "time"

    "gopkg.in/mgo.v2"
)

func main() {
    // 建立连接
    session, err := mgo.Dial("mongodb://localhost:27017")
    if err != nil {
        log.Fatal(err)
    }
    defer session.Close()

    // 获取所选数据库和集合
    db := session.DB("test")
    collection := db.C("users")

    // 插入文档
    if err := collection.Insert(map[string]interface{}{"name": "Alice", "age": 30}); err != nil {
        log.Fatal(err)
    }

    // 查找文档
    result := &struct{ Name string }{Name: ""}
    if err := collection.Find(nil).One(result); err != nil {
        log.Fatal(err)
    }
    fmt.Println("Name:", result.Name)

    // 更新文档
    if _, err := collection.Update(map[string]interface{}{"name": "Alice"}, map[string]interface{}{"age": 31}); err != nil {
        log.Fatal(err)
    }

    // 删除文档
    if err := collection.Remove(map[string]interface{}{"name": "Alice"}); err != nil {
        log.Fatal(err)
    }

}

登录后复制

2. Redis

  • 库: [redigo](https://godoc.org/github.com/garyburd/redigo/redis)
package main

import (
    "fmt"
    "log"

    "github.com/garyburd/redigo/redis"
)

func main() {
    // 建立连接
    conn, err := redis.Dial("tcp", "localhost:6379")
    if err != nil {
        log.Fatal(err)
    }
    defer conn.Close()

    // 设置<a style='color:#f60; text-decoration:underline;' href="https://www.php.cn/zt/49710.html" target="_blank">键值对</a>
    if _, err := conn.Do("SET", "name", "Alice"); err != nil {
        log.Fatal(err)
    }

    // 获取值
    name, err := redis.String(conn.Do("GET", "name"))
    if err != nil {
        log.Fatal(err)
    }
    fmt.Println("Name:", name)

    // 删除键
    if _, err := conn.Do("DEL", "name"); err != nil {
        log.Fatal(err)
    }
}

登录后复制

3. Cassandra

  • 库: [gocql](https://godoc.org/github.com/gocql/gocql)
package main

import (
    "fmt"
    "log"
    "time"

    "github.com/gocql/gocql"
)

func main() {
    // 建立连接
    cluster := gocql.NewCluster("localhost:9042")
    session, err := cluster.CreateSession()
    if err != nil {
        log.Fatal(err)
    }
    defer session.Close()

    // 创建表
    if err := session.Query(`CREATE TABLE users (name text, age int, PRIMARY KEY (name))`).Exec(); err != nil {
        log.Fatal(err)
    }

    // 插入数据
    if err := session.Query(`INSERT INTO users (name, age) VALUES (?, ?)`).Bind("Alice", 30).Exec(); err != nil {
        log.Fatal(err)
    }

    // 查询数据
    iter := session.Query(`SELECT * FROM users`).Iter()
    var name string
    var age int
    for iter.Scan(&name, &age) {
        fmt.Println("Name:", name, "Age:", age)
    }
    if err := iter.Close(); err != nil {
        log.Fatal(err)
    }

    // 更新数据
    if err := session.Query(`UPDATE users SET age = ? WHERE name = ?`).Bind(31, "Alice").Exec(); err != nil {
        log.Fatal(err)
    }

    // 删除数据
    if err := session.Query(`DELETE FROM users WHERE name = ?`).Bind("Alice").Exec(); err != nil {
        log.Fatal(err)
    }
}

登录后复制

以上就是golang框架如何与NoSQL数据库交互?的详细内容,更多请关注叮当号网其它相关文章!

文章来自互联网,只做分享使用。发布者:木子,转转请注明出处:https://www.dingdanghao.com/article/529464.html

(0)
上一篇 2024-05-26 12:00
下一篇 2024-05-26 12:40

相关推荐

联系我们

在线咨询: QQ交谈

邮件:442814395@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信公众号