golang: 把sql結果集以json格式輸出

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

代碼出處:http://stackoverflow.com/questions/19991541/dumping-mysql-tables-to-json-with-golang

func getJSON(sqlString string) (string, error) {stmt, err := db.Prepare(sqlString)if err != nil {return nil, err}defer stmt.Close()rows, err := stmt.Query()if err != nil {return nil, err}defer rows.Close()columns, err := rows.Columns()if err != nil {  return "", err}count := len(columns)tableData := make([]map[string]interface{}, 0)values := make([]interface{}, count)valuePtrs := make([]interface{}, count)for rows.Next() {  for i := 0; i < count; i++ {  valuePtrs[i] = &values[i]  }  rows.Scan(valuePtrs...)  entry := make(map[string]interface{})  for i, col := range columns {  var v interface{}  val := values[i]  b, ok := val.([]byte)  if ok {  v = string(b)  } else {  v = val  }  entry[col] = v  }  tableData = append(tableData, entry)}jsonData, err := json.Marshal(tableData)if err != nil {  return "", err}fmt.Println(string(jsonData))return string(jsonData), nil }


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.