zoukankan      html  css  js  c++  java
  • golang 查询数据库并返回json

    func getJSON(vehicleType string, sqlString string) (string, error) {
        rows, err := mysql.GetDB(vehicleType).Query(sqlString)
        if err != nil {
            return "", 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
    }

    调用:

    start := (i - 1) * pageSize;
            sql := "select id,wnumber from vehicle_steeldust_active where longitude='' OR latitude='' OR active_country='' OR active_province='' OR active_city='' OR active_district='' limit " + strconv.Itoa(start) + "," + strconv.Itoa(pageSize)
            fmt.Println("sql:", sql)
            list, _ := getJSON(vehicleType, string(sql))
            fmt.Println(list)
  • 相关阅读:
    iOS-汽车品牌app
    iOS-英雄联盟人物展示
    工作与梦想中的工作:给计算机专业学生的建议
    c++ 宏的使用
    c++ 预处理的应用
    iOS-UItableView 多组表格
    ios-代理模式 协议小结
    c++有符号变量和无符号变量相加的结果
    ios-图片轮播器
    ios-倒计时
  • 原文地址:https://www.cnblogs.com/rxbook/p/15162029.html
Copyright © 2011-2022 走看看