• 金仓数据库KingbaseES客户端编程接口指南-Gokb (5. 程序示例 )


    5. 程序示例

    以下为几个常用功能的程序示例:

    5.1. 连接数据库

    package main
    
    import (
        "database/sql"
        "fmt"
        _ "kingbase.com/gokb"
    )
    
    const (
        host     = "127.0.0.1"
        port     = 54321
        user     = "system"
        password = "123456"
        dbname   = "TEST"
    )
    
    func main() {
        connInfo := fmt.Sprintf("host=%s port=%d user=%s "+
            "password=%s dbname=%s sslmode=disable",
            host, port, user, password, dbname)
    
        db, err = sql.Open("kingbase", connInfo)
        if err != nil {
            panic(err)
        }
        err = db.Ping()
        if err != nil {
            panic(err)
        }
        fmt.Println("Connection test success!")
        db.Close()
    }
    

    5.2. 获取结果集

    package main
    
    import (
        "database/sql"
        "fmt"
        _ "kingbase.com/gokb"
    )
    
    const (
        host     = "127.0.0.1"
        port     = 54321
        user     = "system"
        password = "123456"
        dbname   = "TEST"
    )
    
    /* 声明表结构 */
    type GoTable struct {
        Num  int    `db:"num"`
        Text string `db:"text"`
        Blob []byte `db:"blob"`
        Clob string `db:"clob"`
    }
    
    
    func main() {
    
        connInfo := fmt.Sprintf("host=%s port=%d user=%s "+
            "password=%s dbname=%s sslmode=disable",
            host, port, user, password, dbname)
    
        db, err = sql.Open("kingbase", connInfo)
        if err != nil {
            panic(err)
        }
        err = db.Ping()
        if err != nil {
            panic(err)
        }
        db.Close()
    
        /* CREATE TABLE temp_golang_test (num INTEGER, text TEXT, blob BLOB, clob CLOB) */
        var data []*GoTable
        rows, err := db.Query("select * from temp_golang_test;")
        defer rows.Close()
        if err != nil {
            return nil, err
        }
    
        for rows.Next() {
            var row GoTable
            err = rows.Scan(&row.Num, &row.Text, &row.Blob, &row.Clob)
            if err != nil {
                return nil, err
            }
    
            data = append(data, &row)
        }
    
        for i := 0; i < len(data); i++ {
            fmt.Println(data[i])
        }
    }
  • 相关阅读:
    调用np.var函数时出现inf值的解决方法
    Excel VLOOKUP 使用记录
    [蓝桥杯 2022 省 B] 刷题统计
    Paramenter-Efficient Transfer Learning for NLP
    星火大模型AI接口Spring中项目中使用【星火、AIGC】
    Jquery 老项目引入vue,elementui
    Mysql有多少种常见的日志,分别解释日志的作用
    Java图书馆借阅功能实现
    Java—继承之题目练习
    tauri vue vite elemrntui
  • 原文地址:https://blog.csdn.net/arthemis_14/article/details/126298156