TeacherStyleVideoMapper.xml 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
  3. <mapper namespace="com.yonge.cooleshow.biz.dal.dao.TeacherStyleVideoDao">
  4. <resultMap id="BaseResultMap" type="com.yonge.cooleshow.biz.dal.entity.TeacherStyleVideo">
  5. <result column="id_" property="id" />
  6. <result column="user_id_" property="userId" />
  7. <result column="video_url_" property="videoUrl" />
  8. <result column="cover_" property="cover" />
  9. <result column="describe_" property="describe" />
  10. <result column="browse_" property="browse" />
  11. <result column="audit_version_" property="auditVersion" />
  12. <result column="auth_status_" property="authStatus" />
  13. <result column="verify_user_id_" property="verifyUserId" />
  14. <result column="reason_" property="reason" />
  15. <result column="entry_flag_" property="entryFlag" />
  16. <result column="create_time_" property="createTime" />
  17. <result column="update_time_" property="updateTime" />
  18. <result column="del_flag_" property="delFlag" />
  19. </resultMap>
  20. <!-- 表字段 -->
  21. <sql id="baseColumns">
  22. t.id_ as id
  23. , t.user_id_ as userId
  24. , t.video_url_ as videoUrl
  25. , t.cover_ as cover
  26. , t.describe_ as `describe`
  27. , t.browse_ as browse
  28. , t.audit_version_ as auditVersion
  29. , t.auth_status_ as authStatus
  30. , t.verify_user_id_ as verifyUserId
  31. , t.reason_ as reason
  32. , t.entry_flag_ as entryFlag
  33. , t.create_time_ as createTime
  34. , t.update_time_ as updateTime
  35. , t.del_flag_ as delFlag
  36. </sql>
  37. <select id="detail" resultType="com.yonge.cooleshow.biz.dal.vo.TeacherStyleVideoVo">
  38. SELECT
  39. <include refid="baseColumns"/>,
  40. u.real_name_ as realName,
  41. u.phone_ as phone,
  42. v.username_ as verifyUser
  43. FROM teacher_style_video t
  44. left join sys_user u on t.user_id_ = u.id_
  45. left join sys_user v on t.verify_user_id_ = v.id_
  46. where u.del_flag_ = 0 and t.id_ = #{id}
  47. </select>
  48. <select id="selectPage" resultType="com.yonge.cooleshow.biz.dal.vo.TeacherStyleVideoVo">
  49. SELECT
  50. <include refid="baseColumns" />,
  51. u.real_name_ as realName,
  52. u.phone_ as phone,
  53. v.username_ as verifyUser
  54. FROM teacher_style_video t
  55. left join sys_user u on t.user_id_ = u.id_
  56. left join sys_user v on t.verify_user_id_ = v.id_
  57. where t.del_flag_ = 0 and u.del_flag_ = 0
  58. <if test="null != param.search and '' != param.search">
  59. AND (
  60. t.user_id_ LIKE CONCAT('%', #{param.search}, '%') or
  61. u.real_name_ LIKE CONCAT('%', #{param.search}, '%') or
  62. u.phone_ LIKE CONCAT('%', #{param.search}, '%')
  63. )
  64. </if>
  65. <if test="null != param.verifyUser and '' != param.verifyUser">
  66. AND v.username_ LIKE CONCAT('%', #{param.verifyUser}, '%')
  67. </if>
  68. <if test="param.startTime !=null">
  69. <![CDATA[AND t.create_time_ >= #{param.startTime} ]]>
  70. </if>
  71. <if test="param.endTime !=null">
  72. <![CDATA[AND t.create_time_ < #{param.endTime} ]]>
  73. </if>
  74. <if test="param.authStatus !=null">
  75. AND t.auth_status_ = #{param.authStatus}
  76. </if>
  77. <if test="param.entryFlag !=null">
  78. AND t.entry_flag_ = #{param.entryFlag}
  79. </if>
  80. order by field(t.auth_status_,'DOING') desc, t.create_time_ desc
  81. </select>
  82. <!-- 根据老师id查询 -->
  83. <select id="selectListByUserId" resultType="com.yonge.cooleshow.biz.dal.entity.TeacherStyleVideo">
  84. SELECT
  85. <include refid="baseColumns"/>
  86. FROM teacher_style_video t
  87. WHERE t.del_flag_ = 0 and t.user_id_ = #{userId}
  88. </select>
  89. <update id="removeByUserIdAndOldIds">
  90. UPDATE teacher_style_video t SET t.del_flag_ = '1'
  91. WHERE t.user_id_ = #{userId}
  92. <if test="oldIds!=null and oldIds.size()>0">
  93. AND t.id_ NOT IN
  94. <foreach collection="oldIds" item="oldId" open="(" close=")" separator=",">
  95. #{oldId}
  96. </foreach>
  97. </if>
  98. </update>
  99. <select id="stylePage" resultType="com.yonge.cooleshow.biz.dal.vo.TeacherStyleVideoVo">
  100. SELECT
  101. <include refid="baseColumns"/>,
  102. ifnull(ta.live_flag_,0) as liveing,
  103. u.avatar_ as avatar,
  104. u.username_ as username
  105. FROM teacher_style_video t
  106. LEFT JOIN teacher a on t.user_id_ = a.user_id_
  107. LEFT JOIN sys_user u on t.user_id_ = u.id_
  108. LEFT JOIN teacher_total ta on t.user_id_ = ta.user_id_
  109. where t.del_flag_ = 0 and a.is_test_user_ = 0 and u.del_flag_ = 0 and t.auth_status_ = 'PASS'
  110. <if test="param.username != null and param.username != ''">
  111. AND u.username_ LIKE CONCAT('%', #{param.username}, '%')
  112. </if>
  113. <if test="param.subjectId != null and param.subjectId != ''">
  114. AND INTE_ARRAY(a.subject_id_,#{param.subjectId})
  115. </if>
  116. <if test="param.auditVersion != null">
  117. and #{param.auditVersion} = t.audit_version_
  118. </if>
  119. order by (ta.fans_num_ * 0.3 + t.browse_ * 0.3 + ta.exp_time_ * 0.4) desc
  120. </select>
  121. <update id="addVideoBrowse">
  122. update teacher_style_video set browse_ = browse_ +1 where id_ = #{videoId}
  123. </update>
  124. </mapper>