userquizpaper title, category 등 추가
This commit is contained in:
		@@ -18,33 +18,49 @@ func NewUserQuizPaperRepository(db *gorm.DB) UserQuizPaperRepository {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type UserQuizPaperRepository interface {
 | 
			
		||||
	List(string, int, int) (*[]models.UserQuizPaper, error)
 | 
			
		||||
	List(string, int, int) (*[]models.UserQuizPaperResponse, error)
 | 
			
		||||
	Total(string) (int64, error)
 | 
			
		||||
 | 
			
		||||
	Find(int64) (*models.UserQuizPaper, error)
 | 
			
		||||
	Find(int64) (*models.UserQuizPaperResponse, error)
 | 
			
		||||
	Get(int64) (*models.UserQuizPaper, error)
 | 
			
		||||
	Create(*models.UserQuizPaper) (*models.UserQuizPaper, error)
 | 
			
		||||
	Insert([]models.UserQuizPaper) ([]models.UserQuizPaper, error)
 | 
			
		||||
	Update(*models.UserQuizPaper) (*models.UserQuizPaper, error)
 | 
			
		||||
	Delete(string) error
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (r *userQuizPaperRepository) List(q string, page int, limit int) (*[]models.UserQuizPaper, error) {
 | 
			
		||||
	var userQuizPapers *[]models.UserQuizPaper
 | 
			
		||||
func (r *userQuizPaperRepository) List(q string, page int, limit int) (*[]models.UserQuizPaperResponse, error) {
 | 
			
		||||
	var rows *[]models.UserQuizPaperResponse
 | 
			
		||||
	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(&userQuizPapers).Error
 | 
			
		||||
		err = r.DB.Offset(offset).Limit(limit).Order("UserQuizPapers.created_at DESC").
 | 
			
		||||
			Table("UserQuizPapers").
 | 
			
		||||
			Select("UserQuizPapers.*", "Users.first_name", "Users.last_name", "QuizPapers.title", "QuizPapers.category").
 | 
			
		||||
			Joins("LEFT JOIN Users ON Users.id = UserQuizPapers.user_id").
 | 
			
		||||
			Joins("LEFT JOIN QuizPapers ON QuizPapers.id = UserQuizPapers.quiz_paper_id").
 | 
			
		||||
			Where("QuizPapers.title LIKE ? OR QuizPapers.category LIKE ? OR CONCAT(first_name, last_name) LIKE ?", "%"+q+"%", "%"+q+"%", "%"+q+"%").
 | 
			
		||||
			Find(&rows).Error
 | 
			
		||||
	} else {
 | 
			
		||||
		err = r.DB.Offset(offset).Limit(limit).Order("created_at DESC").Find(&userQuizPapers).Error
 | 
			
		||||
		err = r.DB.Offset(offset).Limit(limit).Order("UserQuizPapers.created_at DESC").
 | 
			
		||||
			Table("UserQuizPapers").
 | 
			
		||||
			Select("UserQuizPapers.*", "Users.first_name", "Users.last_name", "QuizPapers.title", "QuizPapers.category").
 | 
			
		||||
			Joins("LEFT JOIN Users ON Users.id = UserQuizPapers.user_id").
 | 
			
		||||
			Joins("LEFT JOIN QuizPapers ON QuizPapers.id = UserQuizPapers.quiz_paper_id").
 | 
			
		||||
			Find(&rows).Error
 | 
			
		||||
	}
 | 
			
		||||
	return userQuizPapers, err
 | 
			
		||||
 | 
			
		||||
	return rows, err
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (r *userQuizPaperRepository) Total(q string) (int64, error) {
 | 
			
		||||
	var total int64
 | 
			
		||||
	var err error
 | 
			
		||||
	if q != "" {
 | 
			
		||||
		err = r.DB.Model(&models.UserQuizPaper{}).Where("subject LIKE ? OR program LIKE ? OR name LIKE ?", "%"+q+"%", "%"+q+"%", "%"+q+"%").Count(&total).Error
 | 
			
		||||
		err = r.DB.Model(&models.UserQuizPaper{}).
 | 
			
		||||
			Joins("LEFT JOIN Users ON Users.id = UserQuizPapers.user_id").
 | 
			
		||||
			Joins("LEFT JOIN QuizPapers ON QuizPapers.id = UserQuizPapers.quiz_paper_id").
 | 
			
		||||
			Where("QuizPapers.title LIKE ? OR QuizPapers.category LIKE ? OR CONCAT(first_name, last_name) LIKE ?", "%"+q+"%", "%"+q+"%", "%"+q+"%").Count(&total).Error
 | 
			
		||||
	} else {
 | 
			
		||||
		err = r.DB.Model(&models.UserQuizPaper{}).Count(&total).Error
 | 
			
		||||
	}
 | 
			
		||||
@@ -52,10 +68,23 @@ func (r *userQuizPaperRepository) Total(q string) (int64, error) {
 | 
			
		||||
	return total, err
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (r *userQuizPaperRepository) Find(id int64) (*models.UserQuizPaper, error) {
 | 
			
		||||
	var userQuizPaper *models.UserQuizPaper
 | 
			
		||||
	err := r.DB.Where("id = ?", id).First(&userQuizPaper).Error
 | 
			
		||||
	return userQuizPaper, err
 | 
			
		||||
func (r *userQuizPaperRepository) Find(id int64) (*models.UserQuizPaperResponse, error) {
 | 
			
		||||
	var row *models.UserQuizPaperResponse
 | 
			
		||||
	err := r.DB.
 | 
			
		||||
		Table("UserQuizPapers").
 | 
			
		||||
		Select("UserQuizPapers.*", "Users.first_name", "Users.last_name", "QuizPapers.title", "QuizPapers.category").
 | 
			
		||||
		Joins("LEFT JOIN Users ON Users.id = UserQuizPapers.user_id").
 | 
			
		||||
		Joins("LEFT JOIN QuizPapers ON QuizPapers.id = UserQuizPapers.quiz_paper_id").
 | 
			
		||||
		Where("UserQuizPapers.id = ?", id).First(&row).Error
 | 
			
		||||
	return row, err
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (r *userQuizPaperRepository) Get(id int64) (*models.UserQuizPaper, error) {
 | 
			
		||||
	var row *models.UserQuizPaper
 | 
			
		||||
	if err := r.DB.Where("id=?", id).First(&row).Error; err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return row, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (r *userQuizPaperRepository) Create(userQuizPaper *models.UserQuizPaper) (*models.UserQuizPaper, error) {
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user