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"]) } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Processing语言权威指南
Casey Reas、Ben Fry / 张静 / 电子工业出版社 / 2013-10-1 / 139.00
本书介绍了可视化艺术中的计算机编程概念,对开源编程语言Processing作了非常详尽的阐述。学生、艺术家、设计师、建筑师、研究者,以及任何想编程实现绘画、动画和互动的人都可以使用它。书中的大部分章节是短小的单元,介绍Processing的语法和基本概念(变量、函数、面向对象编程),涵盖与软件相关的图像处理、绘制,并且给出了大量简短的原型程序,配以相应的过程图像与注释。书中还有一些访谈文章,与动画......一起来看看 《Processing语言权威指南》 这本书的介绍吧!