golang mysql查询返回不定字段实现如下:
首先通过func (rs *Rows) Columns() ([]string, error)获取查询字段的slice,然后构造slice,将每次scan出来的值放进去,最后返回查询结果的map slice。
package main
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
func main() {
conn, err := sql.Open("mysql", "root:psw@tcp(localhost:3306)/test?charset=utf8")
if err != nil {
fmt.Println("mysql connect error")
return
}
defer conn.Close()
rows, err := conn.Query("select * from user")
if err != nil {
fmt.Println("mysql query error", err.Error())
}
defer rows.Close()
columns, err := rows.Columns()
values := make([]sql.RawBytes, len(columns))
scans := make([]interface{}, len(columns))
for i := range values {
scans[i] = &values[i]
}
var result []map[string]string
for rows.Next() {
_ = rows.Scan(scans...)
each := make(map[string]string)
for i, col := range values {
each[columns[i]] = string(col)
}
result = append(result, each)
}
fmt.Println(result)
}
同理查询单条也可以这样操作:
func main() {
conn, err := sql.Open("mysql", "root:psw@tcp(localhost:3306)/test?charset=utf8")
if err != nil {
fmt.Println("mysql connect error", err.Error())
return
}
defer conn.Close()
columns := []string{"id", "name"}
id := 1
sql := fmt.Sprintf("select %s from user where id=%d", strings.Join(columns, ", "), id)
row := conn.QueryRow(sql)
values := make([][]byte, len(columns))
scans := make([]interface{}, len(columns))
for i := range values {
scans[i] = &values[i]
}
if err := row.Scan(scans...); err != nil {
fmt.Println("scan error", err.Error())
return
}
var result = make(map[string]string)
for key, val := range values {
result[columns[key]] = string(val)
}
fmt.Println(result)
}
永劫无间手游测试服 安卓版v1.0.262342
下载永劫无间手游台服 安卓版v1.0.262342
下载永劫无间手游国际服 安卓版v1.0.262342
下载永劫无间手游豌豆荚版 安卓版v1.0.262342
下载曼德拉男孩 最新版v2025.1.1
曼德拉男孩是一款专为女性玩家准备的治愈类恋爱游戏,在这里玩家
游戏开发者无限金币版 最新版v1.0.16
游戏开发者内置菜单版是一款非常好玩的模拟经营类手游,内部有功
没有中间商赚差价内购版 最新版v23.7.3
没有中间商赚差价免广告是一款非常好玩的模拟经营类手游,无需看
我的世界某不科学的空岛下载mcbbs 最新版v隔壁老王
我的世界某不科学的空岛整合包是一款像素风格的模拟沙盒游戏,该
洗衣店模拟器无限钞票免广告版 v2.2.2
洗衣店模拟器无限钞票版是一款模拟经营类手游,玩家们将在游戏中