Exam
This commit is contained in:
81
internal/repositories/exam.go
Normal file
81
internal/repositories/exam.go
Normal file
@ -0,0 +1,81 @@
|
||||
package repositories
|
||||
|
||||
import (
|
||||
"learnsteam/learsteam-quiz-api/internal/models"
|
||||
|
||||
"gorm.io/gorm"
|
||||
)
|
||||
|
||||
type examRepository struct {
|
||||
DB *gorm.DB
|
||||
}
|
||||
|
||||
func NewExamRepository(db *gorm.DB) ExamRepository {
|
||||
return &examRepository{
|
||||
DB: db,
|
||||
}
|
||||
}
|
||||
|
||||
type ExamRepository interface {
|
||||
List(string, int, int) (*[]models.Exam, error)
|
||||
Total(string) (int64, error)
|
||||
|
||||
Find(string) (*models.Exam, error)
|
||||
Create(*models.Exam) (*models.Exam, error)
|
||||
Update(*models.Exam) (*models.Exam, error)
|
||||
Delete(string) error
|
||||
}
|
||||
|
||||
func (r *examRepository) List(q string, page int, limit int) (*[]models.Exam, error) {
|
||||
var exams *[]models.Exam
|
||||
var err error
|
||||
offset := limit * (page - 1)
|
||||
if q != "" {
|
||||
err = r.DB.Offset(offset).Limit(limit).Order("created_at DESC").Where("subject LIKE ? OR program LIKE ? OR name LIKE ?", "%"+q+"%", "%"+q+"%", "%"+q+"%").Find(&exams).Error
|
||||
} else {
|
||||
err = r.DB.Offset(offset).Limit(limit).Order("created_at DESC").Find(&exams).Error
|
||||
}
|
||||
return exams, err
|
||||
}
|
||||
|
||||
func (r *examRepository) Total(q string) (int64, error) {
|
||||
var total int64
|
||||
var err error
|
||||
if q != "" {
|
||||
err = r.DB.Model(&models.Exam{}).Where("subject LIKE ? OR program LIKE ? OR name LIKE ?", "%"+q+"%", "%"+q+"%", "%"+q+"%").Count(&total).Error
|
||||
} else {
|
||||
err = r.DB.Model(&models.Exam{}).Count(&total).Error
|
||||
}
|
||||
|
||||
return total, err
|
||||
}
|
||||
|
||||
func (r *examRepository) Find(id string) (*models.Exam, error) {
|
||||
var exam *models.Exam
|
||||
err := r.DB.Where("id = ?", id).First(&exam).Error
|
||||
return exam, err
|
||||
}
|
||||
|
||||
func (r *examRepository) Create(exam *models.Exam) (*models.Exam, error) {
|
||||
err := r.DB.Create(&exam).Error
|
||||
return exam, err
|
||||
}
|
||||
|
||||
func (r *examRepository) Update(exam *models.Exam) (*models.Exam, error) {
|
||||
var row *models.Exam
|
||||
if err := r.DB.Where("id=?", exam.ID).First(&row).Error; err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
err := r.DB.Model(&row).Select("*").Updates(&exam).Error
|
||||
return row, err
|
||||
}
|
||||
|
||||
func (r *examRepository) Delete(id string) error {
|
||||
var exam *models.Exam
|
||||
if err := r.DB.Where("id=?", id).First(&exam).Error; err != nil {
|
||||
return err
|
||||
}
|
||||
err := r.DB.Delete(&exam).Error
|
||||
return err
|
||||
}
|
Reference in New Issue
Block a user