SentenceQuestionService.java 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package com.qxgmat.service.inline;
  2. import com.github.pagehelper.Page;
  3. import com.nuliji.tools.AbstractService;
  4. import com.nuliji.tools.Transform;
  5. import com.nuliji.tools.exception.ParameterException;
  6. import com.nuliji.tools.exception.SystemException;
  7. import com.nuliji.tools.mybatis.Example;
  8. import com.qxgmat.data.dao.SentenceQuestionMapper;
  9. import com.qxgmat.data.dao.entity.Manager;
  10. import com.qxgmat.data.dao.entity.Question;
  11. import com.qxgmat.data.dao.entity.SentenceQuestion;
  12. import com.qxgmat.data.relation.entity.SentenceQuestionRelation;
  13. import org.slf4j.Logger;
  14. import org.slf4j.LoggerFactory;
  15. import org.springframework.stereotype.Service;
  16. import javax.annotation.Resource;
  17. import java.util.Collection;
  18. import java.util.List;
  19. @Service
  20. public class SentenceQuestionService extends AbstractService {
  21. private static final Logger logger = LoggerFactory.getLogger(SentenceQuestionService.class);
  22. @Resource
  23. private SentenceQuestionMapper sentenceQuestionMapper;
  24. @Resource
  25. private QuestionService questionService;
  26. /**
  27. * 根据长难句题目关系,获取完整题目:列表
  28. * @param p
  29. * @return
  30. */
  31. public List<SentenceQuestionRelation> relation(List<SentenceQuestion> p){
  32. List<SentenceQuestionRelation> relationList = Transform.convert(p, SentenceQuestionRelation.class);
  33. Collection questionIds = Transform.getIds(p, SentenceQuestion.class, "questionId");
  34. List<Question> questions = questionService.select(questionIds);
  35. Transform.combine(relationList, questions, SentenceQuestionRelation.class, "questionId", "question", Question.class, "id");
  36. return relationList;
  37. }
  38. /**
  39. * 根据长难句题目关系,获取完整题目:单个
  40. * @param p
  41. * @return
  42. */
  43. public SentenceQuestionRelation relation(SentenceQuestion p){
  44. SentenceQuestionRelation relation = Transform.convert(p, SentenceQuestionRelation.class);
  45. Question question = questionService.get(p.getQuestionId());
  46. relation.setQuestion(question);
  47. return relation;
  48. }
  49. /**
  50. * 根据序号查询
  51. * @param no
  52. * @return
  53. */
  54. public SentenceQuestion getByNo(Integer no){
  55. Example example = new Example(SentenceQuestion.class);
  56. example.and(
  57. example.createCriteria()
  58. .andEqualTo("no", no)
  59. );
  60. return one(sentenceQuestionMapper, example);
  61. }
  62. public SentenceQuestion add(SentenceQuestion question){
  63. int result = insert(sentenceQuestionMapper, question);
  64. question = one(sentenceQuestionMapper, question.getId());
  65. if(question == null){
  66. throw new SystemException("题目添加失败");
  67. }
  68. return question;
  69. }
  70. public SentenceQuestion edit(SentenceQuestion question){
  71. SentenceQuestion in = one(sentenceQuestionMapper, question.getId());
  72. if(in == null){
  73. throw new ParameterException("题目不存在");
  74. }
  75. int result = update(sentenceQuestionMapper, question);
  76. return question;
  77. }
  78. public boolean delete(Number id){
  79. SentenceQuestion in = one(sentenceQuestionMapper, id);
  80. if(in == null){
  81. throw new ParameterException("题目不存在");
  82. }
  83. int result = delete(sentenceQuestionMapper, id);
  84. return result > 0;
  85. }
  86. public SentenceQuestion get(Number id){
  87. SentenceQuestion in = one(sentenceQuestionMapper, id);
  88. if(in == null){
  89. throw new ParameterException("题目不存在");
  90. }
  91. return in;
  92. }
  93. public Page<SentenceQuestion> select(int page, int pageSize){
  94. return select(sentenceQuestionMapper, page, pageSize);
  95. }
  96. public List<SentenceQuestion> select(Collection ids){
  97. return select(sentenceQuestionMapper, ids);
  98. }
  99. }