go-common/app/admin/ep/melloi/dao/rank.go
2019-04-22 18:49:16 +08:00

148 lines
7.5 KiB
Go

package dao
import (
"go-common/app/admin/ep/melloi/model"
)
//TreesQuery query department and performance test count of department
func (d *Dao) TreesQuery() (res *model.TreeList, err error) {
res = &model.TreeList{}
//select department, count(department) as count from report_summary where department != '' GROUP BY department ORDER BY count desc
err = d.DB.Table("report_summary").Select("department, project, app").Group("app").
Having("department != ''").Order("department").Scan(&res.TreeList).Error
return
}
//TreeNumQuery query department
func (d *Dao) TreeNumQuery() (res *model.NumList, err error) { /**/
res = &model.NumList{}
//select count(DISTINCT department) as count from report_summary where department != ''
if err = d.DB.Table("report_summary").Select("department, count(DISTINCT department) as dept_num").
Where("department != ''").Scan(&res.NumList).Error; err != nil {
return
}
if err = d.DB.Table("report_summary").Select("project, count(DISTINCT project) as pro_num").
Where("project != ''").Scan(&res.NumList).Error; err != nil {
return
}
if err = d.DB.Table("report_summary").Select("app, count(DISTINCT app) as app_num").
Where("app != ''").Scan(&res.NumList).Error; err != nil {
return
}
return
}
//TopHttpQuery query performance test top api
func (d *Dao) TopHttpQuery() (res *model.TopAPIRes, err error) {
res = &model.TopAPIRes{}
//select s.url, count(r.script_id) as count from report_summary r INNER JOIN script s on r.script_id = s.id GROUP BY s.url having url != '' ORDER BY count desc
err = d.DB.Limit(10).Table("report_summary").Select("script.url, count(report_summary.script_id) as count").
Joins("inner join script on report_summary.script_id = script.id").
Where("report_summary.active = 1 and report_summary.debug != 1 and script.test_type = 1 and report_summary.type = 0").
Group("script.url").Having("script.url != ''").Order("count desc").Scan(&res.APIList).Error
return
}
//TopGrpcQuery Top Grpc Query
func (d *Dao) TopGrpcQuery() (res *model.GrpcRes, err error) {
res = &model.GrpcRes{}
//select g.service_name, g.request_method, count(r.script_id) as count from report_summary r INNER JOIN grpc g on r.script_id = g.id
//where g.service_name != '' and r.active = 1 and r.debug != 1 and r.type = 1
//GROUP BY g.service_name ORDER BY count desc
err = d.DB.Limit(10).Table("report_summary").Select("grpc.service_name, grpc.request_method, count(report_summary.script_id) as count").
Joins("inner join grpc on report_summary.script_id = grpc.id").
Where("report_summary.active = 1 and report_summary.debug != 1 and grpc.service_name != '' and report_summary.type = 1").
Group("grpc.service_name").Order("count desc").Scan(&res.GrpcList).Error
return
}
//TopSceneQuery Top Scene Query
func (d *Dao) TopSceneQuery() (res *model.SceneRes, err error) {
res = &model.SceneRes{}
//select s.scene_name, count(r.script_id) as count from report_summary r INNER JOIN scene s on r.scene_id = s.id
//where s.scene_name != '' and s.is_active = 1 and s.is_draft = 0 and r.active = 1 and r.debug != 1 and r.scene_id != 0 and r.type = 2
//GROUP BY s.scene_name ORDER BY count desc
err = d.DB.Limit(10).Table("report_summary").Select("scene.department, scene.scene_name, count(report_summary.script_id) as count").
Joins("inner join scene on report_summary.scene_id = scene.id").
Where("report_summary.active = 1 and report_summary.debug != 1 and scene.scene_name != '' and scene.is_active = 1 and scene.is_draft = 0 and report_summary.scene_id != 0 and report_summary.type = 2").
Group("scene.scene_name").Order("count desc").Scan(&res.SceneList).Error
return
}
//TopDeptQuery query performance test top department
func (d *Dao) TopDeptQuery() (res *model.TopDeptRes, err error) {
res = &model.TopDeptRes{}
//select department, count(department) as count from report_summary where department != '' GROUP BY department ORDER BY count desc
err = d.DB.Limit(10).Table("report_summary").Select("department, count(department) as count").
Where("report_summary.active = 1 and report_summary.debug != 1").
Group("department").Having("department != ''").Order("count desc").Scan(&res.DeptList).Error
return
}
//BuildLineQuery query performance test count by time
func (d *Dao) BuildLineQuery(rank *model.Rank, summary *model.ReportSummary) (res *model.BuildLineRes, err error) {
res = &model.BuildLineRes{}
//select DATE_FORMAT(ctime, '%H') as count from report_summary where ctime >= date_sub(now(), interval 24 hour) AND ctime <= NOW()
//switch rank.TimeDegree {
//case "H":
// err = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y-%m-%d %H') as date").
// Where(summary).Where("active = 1 and debug != 1").
// Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime).Order("date").
// Scan(&res.BuildList).Error
//case "d":
// err = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y-%m-%d') as date").Where(summary).
// Where("active = 1 and debug != 1").
// Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime).Order("date").Scan(&res.BuildList).Error
//case "m":
// err = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y-%m') as date").Where(summary).
// Where("active = 1 and debug != 1").
// Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime).Order("date").Scan(&res.BuildList).Error
//case "Y":
// err = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y') as date").Where(summary).
// Where("active = 1 and debug != 1").
// Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime).Order("date").Scan(&res.BuildList).Error
//default:
// err = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y-%m-%d %H') as date").Where(summary).
// Where("active = 1 and debug != 1").
// Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime).Order("date").Scan(&res.BuildList).Error
//}
gDB := d.DB.Table(model.ReportSummary{}.TableName())
switch rank.TimeDegree {
case "H":
gDB = gDB.Select("DATE_FORMAT(ctime, '%Y-%m-%d %H') as date").
Where("active = 1 and debug != 1").
Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime)
case "d":
gDB = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y-%m-%d') as date").
Where("active = 1 and debug != 1").
Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime)
case "m":
gDB = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y-%m') as date").
Where("active = 1 and debug != 1").
Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime)
case "Y":
gDB = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y') as date").
Where("active = 1 and debug != 1").
Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime)
default:
gDB = d.DB.Table("report_summary").Select("DATE_FORMAT(ctime, '%Y-%m-%d %H') as date").
Where("active = 1 and debug != 1").
Where("ctime >= ? AND ctime <= ?", rank.StartTime, rank.EndTime)
}
if rank.SearchAll {
err = gDB.Where("type in (0, 1, 2)").Order("date").Scan(&res.BuildList).Error
} else {
err = gDB.Where("type = ?", summary.Type).Order("date").Scan(&res.BuildList).Error
}
return
}
//StateLineQuery query statistic of state
func (d *Dao) StateLineQuery() (res *model.StateLineRes, err error) {
res = &model.StateLineRes{}
//select test_status, count(test_status) as count from report_summary GROUP BY test_status
err = d.DB.Table("report_summary").Select("test_status, count(test_status) as count").Where("test_status != 0").
Where("active = 1 and debug != 1").Group("test_status").Scan(&res.StateList).Error
return
}