123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- 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
- }
|