Beispiel #1
0
        /// <summary>
        /// Save teacher's mark to Answer.IsCorrect
        /// </summary>
        /// <param name="answerData"></param>
        public void ConfirmAnswer(ConfirmAnswerDBRequest answerData)
        {
            string updateQueryIsCorrect = @"UPDATE Answers SET IsCorrect = @IsCorrect WHERE Answers.QuestionId = @QuestionId AND Answers.UserId = @UserId";

            using (var con = OpenConnection())
            {
                con.Execute(updateQueryIsCorrect, new { answerData.IsCorrect, answerData.QuestionId, answerData.UserId });
            }
        }
Beispiel #2
0
        /// <summary>
        /// Update user score for the survey if isCorrect request == true
        /// </summary>
        /// <param name="answerData"></param>
        public void UpdateSurveyScore(ConfirmAnswerDBRequest answerData)
        {
            string updateQueryScore = @"UPDATE UserSurveyList SET Score = UserSurveyList.Score + Questions.Score FROM Questions INNER JOIN UserSurveyList ON Questions.Id = @QuestionId AND UserSurveyList.UserId = @UserId AND Questions.SurveyId = UserSurveyList.SurveyId";

            using (var con = OpenConnection())
            {
                con.Execute(updateQueryScore, new { answerData.QuestionId, answerData.UserId });
            }
        }
Beispiel #3
0
        /// <summary>
        /// Check is exist id, save isCorrect in db and if isCorrect == true - update score for user
        /// </summary>
        ///<table style=""width:100%"">
        ///<tr>
        ///    <th>ERROR#</th>
        ///    <th>ERROR CODE</th>
        ///    <th>ERROR DESCRIPTION</th>
        ///</tr>
        ///<tr>
        ///    <td>5012</td>
        ///    <td>NOT_EXIST_QUESTION_ID</td>
        ///    <td>Question Id is not exist in data base</td>
        ///</tr>
        ///<tr>
        ///    <td>5011</td>
        ///    <td>NOT_EXIST_USER_ID</td>
        ///    <td>Student Id is not exist in data base</td>
        ///</tr>
        ///<tr>
        ///    <td>9006</td>
        ///    <td>DATA_BASE_ERROR</td>
        ///    <td></td>
        ///</tr>
        ///</table>
        /// <param name="questionId"></param>
        /// <param name="studentId"></param>
        /// <param name="request"></param>
        /// <returns></returns>
        public Errors ConfirmAnswer(int questionId, int studentId, ConfirmAnswerRequest request)
        {
            try
            {
                if (!_dbManager.isExistUserId(studentId))
                {
                    return(Errors.NOT_EXIST_USER_ID);
                }

                if (!_dbManager.isExistQuestionId(questionId))
                {
                    return(Errors.NOT_EXIST_QUESTION_ID);
                }

                ConfirmAnswerDBRequest answer = new ConfirmAnswerDBRequest()
                {
                    QuestionId = questionId,
                    UserId     = studentId,
                    IsCorrect  = request.IsCorrect
                };

                _dbManager.ConfirmAnswer(answer);

                if (request.IsCorrect)
                {
                    _dbManager.UpdateSurveyScore(answer);
                }

                return(Errors.OK);
            }
            catch (Exception ex)
            {
                _logger.Error(ex.Message);
                return(Errors.DATA_BASE_ERROR);
            }
        }