首页 > 文章列表 > Go语言常用的数据库系统有哪些?

Go语言常用的数据库系统有哪些?

mysql MongoDB
176 2024-03-27

标题:Go语言中支持的流行数据库系统及示例

Go语言作为一种高效、简洁的开发语言,其对数据库的支持也是非常广泛的。在Go语言中,开发者可以方便地操作多种流行的数据库系统,包括MySQL、PostgreSQL、MongoDB等。本文将介绍Go语言中支持的几种流行数据库系统,并给出每种数据库的相应代码示例。

1. MySQL

MySQL是一种常用的关系型数据库系统,Go语言可以通过第三方库进行MySQL的连接和操作。下面是一个简单的示例代码,演示了如何使用Go语言连接MySQL数据库,并查询数据:

package main

import (
    "database/sql"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    db, err := sql.Open("mysql", "username:password@tcp(localhost:3306)/dbname")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()

    rows, err := db.Query("SELECT * FROM users")
    if err != nil {
        panic(err.Error())
    }

    defer rows.Close()

    for rows.Next() {
        var id int
        var name string
        err = rows.Scan(&id, &name)
        if err != nil {
            panic(err.Error())
        }
        fmt.Println(id, name)
    }
}

2. PostgreSQL

PostgreSQL是一种开源的关系型数据库系统,Go语言也提供了对PostgreSQL的支持。下面是一个简单的示例代码,演示了如何使用Go语言连接PostgreSQL数据库,并插入数据:

package main

import (
    "database/sql"
    "fmt"
    _ "github.com/lib/pq"
)

func main() {
    db, err := sql.Open("postgres", "user=username password=password dbname=dbname sslmode=disable")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()

    _, err = db.Exec("INSERT INTO users (name) VALUES ('Alice')")
    if err != nil {
        panic(err.Error())
    }

    fmt.Println("Data inserted successfully")
}

3. MongoDB

MongoDB是一种非关系型数据库系统,Go语言可以通过第三方库进行MongoDB的连接和操作。下面是一个简单的示例代码,演示了如何使用Go语言连接MongoDB数据库,并插入数据:

package main

import (
    "context"
    "fmt"
    "go.mongodb.org/mongo-driver/mongo"
    "go.mongodb.org/mongo-driver/mongo/options"
)

type User struct {
    Name string
    Age  int
}

func main() {
    clientOptions := options.Client().ApplyURI("mongodb://localhost:27017")
    client, err := mongo.Connect(context.Background(), clientOptions)
    if err != nil {
        panic(err.Error())
    }
    defer client.Disconnect(context.Background())

    collection := client.Database("mydb").Collection("users")

    user := User{Name: "Bob", Age: 30}
    _, err = collection.InsertOne(context.Background(), user)
    if err != nil {
        panic(err.Error())
    }

    fmt.Println("Data inserted successfully")
}

以上是Go语言中支持的几种流行数据库系统以及相应的代码示例。开发者可以根据自己的需求选择合适的数据库系统,并通过Go语言轻松地进行数据库操作。