-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathaverage_rating_computation.go
117 lines (100 loc) · 4.76 KB
/
average_rating_computation.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package cron
import (
"github.com/TUM-Dev/Campus-Backend/server/model"
log "github.com/sirupsen/logrus"
)
// averageRatingComputation
// This cronjob precomputes average ratings of all cafeteria ratings, dish ratings and all three types of tags.
// They are grouped (e.g. All Ratings for "Mensa_garching") and the computed values will then be stored in a table with the suffix "_result"
func (c *CronService) averageRatingComputation() error {
computeAverageForCafeteria(c)
computeAverageForDishesInCafeterias(c)
computeAverageCafeteriaTags(c)
computeAverageForDishesInCafeteriasTags(c)
computeAverageNameTags(c)
return nil
}
func computeAverageNameTags(c *CronService) {
var results []model.DishNameTagAverage
err := c.db.Raw("SELECT mr.cafeteriaID as cafeteriaID, mnt.tagnameID as tagID, AVG(mnt.points) as average, MAX(mnt.points) as max, MIN(mnt.points) as min, STD(mnt.points) as std" +
" FROM dish_rating mr" +
" JOIN dish_name_tag mnt ON mr.dishRating = mnt.correspondingRating" +
" GROUP BY mr.cafeteriaID, mnt.tagnameID").Scan(&results).Error
if err != nil {
log.WithError(err).Error("while precomputing average name tags.")
} else if len(results) > 0 {
if err := c.db.Where("1=1").Delete(&model.DishNameTagAverage{}).Error; err != nil {
log.WithError(err).Error("Error while deleting old averages in the table.")
}
if err := c.db.Create(&results).Error; err != nil {
log.WithError(err).Error("while creating a new average name tag rating in the database.")
}
}
}
func computeAverageForDishesInCafeteriasTags(c *CronService) {
var results []model.DishRatingTagAverage //todo namen im select anpassen
err := c.db.Raw("SELECT mr.dishID as dishID, mr.cafeteriaID as cafeteriaID, mrt.tagID as tagID, AVG(mrt.points) as average, MAX(mrt.points) as max, MIN(mrt.points) as min, STD(mrt.points) as std" +
" FROM dish_rating mr" +
" JOIN dish_rating_tag mrt ON mr.dishRating = mrt.parentRating" +
" GROUP BY mr.cafeteriaID, mrt.tagID, mr.dishID").Scan(&results).Error
if err != nil {
log.WithError(err).Error("while precomputing average dish tags.")
} else if len(results) > 0 {
if err := c.db.Where("1=1").Delete(&model.DishRatingTagAverage{}).Error; err != nil {
log.WithError(err).Error("Error while deleting old averages in the table.")
}
if err := c.db.Create(&results).Error; err != nil {
log.WithError(err).Error("while creating a new average dish tag rating in the database.")
}
}
}
func computeAverageCafeteriaTags(c *CronService) {
var results []model.CafeteriaRatingTagsAverage
err := c.db.Raw("SELECT cr.cafeteriaID as cafeteriaID, crt.tagID as tagID, AVG(crt.points) as average, MAX(crt.points) as max, MIN(crt.points) as min, STD(crt.points) as std" +
" FROM cafeteria_rating cr" +
" JOIN cafeteria_rating_tag crt ON cr.cafeteriaRating = crt.correspondingRating" +
" GROUP BY cr.cafeteriaID, crt.tagID").Scan(&results).Error
if err != nil {
log.WithError(err).Error("while precomputing average cafeteria tags.")
} else if len(results) > 0 {
if err := c.db.Where("1=1").Delete(&model.CafeteriaRatingTagsAverage{}).Error; err != nil {
log.WithError(err).Error("Error while deleting old averages in the table.")
}
if err := c.db.Create(&results).Error; err != nil {
log.WithError(err).Error("while creating a new average cafeteria tag rating in the database.")
}
}
}
func computeAverageForDishesInCafeterias(c *CronService) {
var results []model.DishRatingAverage
err := c.db.Model(&model.DishRating{}).
Select("cafeteriaID, dishID, AVG(points) as average, MAX(points) as max, MIN(points) as min, STD(points) as std").
Group("cafeteriaID,dishID").Scan(&results).Error
if err != nil {
log.WithError(err).Error("while precomputing average dish ratings.")
} else if len(results) > 0 {
if err := c.db.Where("1=1").Delete(&model.DishRatingAverage{}).Error; err != nil {
log.WithError(err).Error("Error while deleting old averages in the table.")
}
if err := c.db.Create(&results).Error; err != nil {
log.WithError(err).Error("while creating a new average dish rating in the database.")
}
}
}
func computeAverageForCafeteria(c *CronService) {
var results []model.CafeteriaRatingAverage
err := c.db.Model(&model.CafeteriaRating{}).
Select("cafeteriaID, AVG(points) as average, MAX(points) as max, MIN(points) as min, STD(points) as std").
Group("cafeteriaID").Find(&results).Error
if err != nil {
log.WithError(err).Error("while precomputing average cafeteria ratings.")
} else if len(results) > 0 {
if err := c.db.Where("1=1").Delete(&model.CafeteriaRatingAverage{}).Error; err != nil {
log.WithError(err).Error("Error while deleting old averages in the table.")
}
err := c.db.Create(&results).Error
if err != nil {
log.WithError(err).Error("while creating a new average cafeteria rating in the database.")
}
}
}