mirror of
https://gitee.com/goploy/goploy.git
synced 2024-12-05 21:48:39 +08:00
52 lines
1.1 KiB
Go
52 lines
1.1 KiB
Go
package model
|
|
|
|
import (
|
|
"time"
|
|
)
|
|
|
|
// Chart struct
|
|
type Chart struct {
|
|
Hour int `json:"hour"`
|
|
CommitNumber int `json:"commitNumber"`
|
|
DeployNumber int `json:"deployNumber"`
|
|
FailNumber int `json:"failNumber"`
|
|
BackNumber int `json:"backNumber"`
|
|
}
|
|
|
|
// Charts struct
|
|
type Charts []Chart
|
|
|
|
// Query chart row
|
|
func (c *Charts) Query(date string) error {
|
|
t, err := time.ParseInLocation("2006-01-02", date, time.Local)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
startTimestamp := t.Unix()
|
|
endTimestamp := startTimestamp + 86400
|
|
rows, err := DB.Query(
|
|
`SELECT
|
|
FROM_UNIXTIME(create_time, '%H')as hour,
|
|
COUNT(*) as commit,
|
|
COUNT(status = 2 or null) as deploy,
|
|
COUNT(status = 3 or null) as fail,
|
|
COUNT(status = 4 or null) as back
|
|
FROM deploy
|
|
WHERE create_time BETWEEN ? AND ?
|
|
GROUP BY hour
|
|
Order BY null`,
|
|
startTimestamp,
|
|
endTimestamp)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
for rows.Next() {
|
|
var chart Chart
|
|
if err := rows.Scan(&chart.Hour, &chart.CommitNumber, &chart.DeployNumber, &chart.FailNumber, &chart.BackNumber); err != nil {
|
|
return err
|
|
}
|
|
*c = append(*c, chart)
|
|
}
|
|
return nil
|
|
}
|