go 简单读取数据库

/*
go-sqlite3 is cgo package.
If you want to build your app using go-sqlite3, you need gcc. However,
after you have built and installed go-sqlite3 with go install github.com/mattn/go-sqlite3 (which requires gcc),
you can build your app without relying on gcc in future.

Important: because this is a CGO enabled package,
you are required to set the environment variable CGO_ENABLED=1 and have a gcc compile present within your path.
*/

package main

import (
	"database/sql"
	"fmt"
	"io"
	"log"
	"net/http"

	_ "github.com/mattn/go-sqlite3"
)

var databasePath = "./data.db3"

type SoInfo struct {
	id          int
	build_id    int
	branch      string
	resversion  string
	currenttime string
}

func checkError(err error) {
	if err != nil {
		log.Fatal(err)
	}
}

func handler(w http.ResponseWriter, r *http.Request) {
	r.ParseForm()
	if len(r.Form) > 0 {
		job_name := r.Form.Get("job_name")
		if len(job_name) != 0 {
			db, err := sql.Open("sqlite3", databasePath)
			checkError(err)
			defer db.Close()

			sql := fmt.Sprintf("select id,build_id,branch,resversion,currenttime from so_records where job_name='%s' order by cast(build_id as '999999') desc limit 20", job_name)
			rows, err := db.Query(sql)
			checkError(err)
			defer rows.Close()
			for rows.Next() {
				var line SoInfo
				rows.Scan(&line.id, &line.build_id, &line.branch, &line.resversion, &line.currenttime)
				stringLine := fmt.Sprintf("BuildID: %d | BRANCH: %s | RESVERSION:%s | Time: %s | ID: %d\n", line.build_id, line.branch, line.resversion, line.currenttime, line.id)
				io.WriteString(w, stringLine)
			}
		}
	}
}

func main() {
	http.HandleFunc("/findso", handler)
	err := http.ListenAndServe(":8080", nil)
	if err != nil {
		log.Fatal("ListenAndServe: ", err)
	}
}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小鱼游戏开发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值