148 lines
7.5 KiB
Go
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
|
||
|
}
|