go语言将表数据动态转成切片(字段任意拓展)

栏目: Go · 发布时间: 7年前

package main

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

//先把字段的值都当成字符串
func Rows2SliceMap(rows *sql.Rows) (list []map[string]string) {
    //字段名称
    columns, _ := rows.Columns()
    //多少个字段
    length := len(columns)
    //每一行字段的值
    values := make([]sql.RawBytes, length)
    //保存的是values的内存地址
    pointer := make([]interface{}, length)
    //
    for i := 0; i < length; i++ {
        pointer[i] = &values[i]
    }
    //
    for rows.Next() {
        //把参数展开,把每一行的值存到指定的内存地址去,循环覆盖,values也就跟着被赋值了
        rows.Scan(pointer...)
        //每一行
        row := make(map[string]string)
        for i := 0; i < length; i++ {
            row[columns[i]] = string(values[i])
        }
        list = append(list, row)
    }
    //
    return
}

func main() {
    db, err := sql.Open("mysql", "root:1234@tcp(192.168.99.165:3306)/test?charset=utf8")
    if err != nil {
        log.Println(err.Error())
    }
    err = db.Ping()
    if err != nil {
        log.Println(err.Error())
    }
    rows, _ := db.Query("select * from cms")
    defer rows.Close()
    list := Rows2SliceMap(rows)
    for k, v := range list {
        fmt.Println(k)
        fmt.Println(v["id"], v["name"], v["sex"], v["age"])
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Learning JavaScript

Learning JavaScript

Shelley Powers / Oreilly & Associates Inc / 2006-10-17 / $29.99

As web browsers have become more capable and standards compliant, JavaScript has grown in prominence. JavaScript lets designers add sparkle and life to web pages, while more complex JavaScript has led......一起来看看 《Learning JavaScript》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具