123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304 |
- <?xml version="1.0" encoding="UTF-8" ?>
- <!DOCTYPE mapper
- PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
- <mapper namespace="com.zhongzheng.modules.user.mapper.UserSubscribeMapper">
- <resultMap type="com.zhongzheng.modules.user.domain.UserSubscribe" id="UserSubscribeResult">
- <result property="subscribeId" column="subscribe_id"/>
- <result property="goodsId" column="goods_id"/>
- <result property="userId" column="user_id"/>
- <result property="subscribeStatus" column="subscribe_status"/>
- <result property="beforeStatus" column="before_status"/>
- <result property="examStatus" column="exam_status"/>
- <result property="performance" column="performance"/>
- <result property="result" column="result"/>
- <result property="certificateCode" column="certificate_code"/>
- <result property="applyId" column="apply_id"/>
- <result property="studentType" column="student_type"/>
- <result property="examExpend" column="exam_expend"/>
- <result property="beforeExpend" column="before_expend"/>
- <result property="createTime" column="create_time"/>
- <result property="updateTime" column="update_time"/>
- <result property="importNo" column="import_no"/>
- </resultMap>
- <resultMap type="com.zhongzheng.modules.user.vo.UserSubscribeVo" id="UserSubscribeVo">
- <result property="subscribeId" column="subscribe_id"/>
- <result property="goodsId" column="goods_id"/>
- <result property="userId" column="user_id"/>
- <result property="subscribeStatus" column="subscribe_status"/>
- <result property="beforeStatus" column="before_status"/>
- <result property="examStatus" column="exam_status"/>
- <result property="performance" column="performance"/>
- <result property="result" column="result"/>
- <result property="certificateCode" column="certificate_code"/>
- <result property="applyId" column="apply_id"/>
- <result property="studentType" column="student_type"/>
- <result property="examExpend" column="exam_expend"/>
- <result property="beforeExpend" column="before_expend"/>
- <result property="createTime" column="create_time"/>
- <result property="goodsName" column="goods_name"/>
- <result property="categoryName" column="category_name"/>
- <result property="goodsCode" column="goods_code"/>
- <result property="remark" column="remark"/>
- <result property="standPrice" column="stand_price"/>
- <result property="realname" column="realname"/>
- <result property="idCard" column="id_card"/>
- <result property="applyName" column="apply_name"/>
- <result property="beforeId" column="before_id"/>
- <result property="beforeName" column="before_name"/>
- <result property="applySiteAddress" column="apply_site_address"/>
- <result property="applySiteStartTime" column="apply_site_start_time"/>
- <result property="applySiteEndTime" column="apply_site_end_time"/>
- <result property="applySiteExamTime" column="apply_site_exam_time"/>
- <result property="applySiteAddressTrain" column="apply_site_address_train"/>
- <result property="applySiteStartTrainTime" column="apply_site_start_train_time"/>
- <result property="applySiteEndTrainTime" column="apply_site_end_train_time"/>
- <result property="applySiteExamTrainTime" column="apply_site_exam_train_time"/>
- <result property="applyStartTime" column="apply_start_time"/>
- <result property="applyEndTime" column="apply_end_time"/>
- <result property="businessId" column="business_id"/>
- <result property="beforeCount" column="before_count"/>
- <result property="beforeName" column="before_name"/>
- <result property="importNo" column="import_no"/>
- </resultMap>
- <select id="listSubscribe" parameterType="com.zhongzheng.modules.user.bo.UserSubscribeQueryBo" resultMap="UserSubscribeVo">
- SELECT
- us.*, eb.before_name,
- (SELECT g.goods_name FROM goods g where us.goods_id = g.goods_id) as goods_name,
- (SELECT g.code FROM goods g where us.goods_id = g.goods_id) as goods_code,
- (SELECT g.stand_price FROM goods g where us.goods_id = g.goods_id) as stand_price,
- (SELECT m.category_name FROM goods g LEFT JOIN major m on g.major_id= m.id where us.goods_id = g.goods_id) as category_name,
- u.realname,
- u.id_card,
- (SELECT ea.apply_name FROM exam_apply ea where ea.apply_id = us.apply_id) as apply_name,
- (SELECT ea.apply_start_time FROM exam_apply ea where ea.apply_id = us.apply_id) as apply_start_time,
- (SELECT ea.apply_end_time FROM exam_apply ea where ea.apply_id = us.apply_id) as apply_end_time,
- (SELECT eb.before_name FROM exam_before eb where eb.before_id = us.before_id) as before_name,
- (SELECT ueg.do_number-ueg.expend_before FROM user_exam_goods ueg where ueg.goods_id = us.goods_id and ueg.user_id = us.user_id ORDER BY user_exam_goods_id DESC limit 1) as before_count
- FROM
- user_subscribe us
- LEFT JOIN exam_before eb ON us.before_id = eb.before_id
- LEFT JOIN `user` u ON us.user_id = u.user_id
- WHERE
- 1 =1
- <if test="applySiteAddress != null and applySiteAddress != '' ">
- and us.apply_site_address = #{applySiteAddress}
- </if>
- <if test="canCancel != null and canCancel == 1 ">
- and us.subscribe_status = 1
- and LEFT(us.apply_site_start_time,2)*3600+RIGHT(us.apply_site_start_time,2)*60+us.apply_site_exam_time > unix_timestamp(now())
- and us.exam_status = 0
- and us.before_status = 0
- </if>
- <if test="canBefore != null and canBefore == 1 ">
- and us.subscribe_status = 1
- and us.exam_status = 0
- and us.before_id = #{beforeId}
- and (SELECT count(*) from exam_before_goods ebg where ebg.before_id = #{beforeId} and ebg.goods_id = us.goods_id) >0
- and (us.before_status = 1 or (SELECT count(*) from user_exam_goods ueg where ueg.user_id = us.user_id and ueg.goods_id = us.goods_id and ueg.do_number - ueg.expend_before>0)>0)
- </if>
- <if test="canExam != null and canExam == 1 ">
- and us.subscribe_status = 1
- </if>
- <if test="searchKey != null and searchKey != '' and searchType == 0 ">
- and (u.realname like concat('%', #{searchKey}, '%') or u.id_card like concat('%', #{searchKey}, '%'))
- </if>
- <if test="idCards != null and idCards.size()!=0 and searchType == 0" >
- AND u.id_card in
- <foreach collection="idCards" item="item" index="index" open="(" close=")" separator=",">
- #{item}
- </foreach>
- </if>
- <if test="searchType == 1" >
- and (u.realname like concat('%', #{searchKey}, '%') or u.id_card like concat('%', #{searchKey}, '%') or
- u.id_card in
- <foreach collection="idCards" item="item" index="index" open="(" close=")" separator=",">
- #{item}
- </foreach>)
- </if>
- <if test="userId != null and userId != '' ">
- and us.user_id = #{userId}
- </if>
- <if test="goodsId != null and goodsId != '' ">
- and us.goods_id = #{goodsId}
- </if>
- <if test="result != null ">
- and us.result = #{result}
- </if>
- <if test="subscribeId != null and subscribeId != '' ">
- and us.subscribe_id = #{subscribeId}
- </if>
- <if test="subscribeStatus != null and subscribeStatus != '' ">
- and us.subscribe_status = #{subscribeStatus}
- </if>
- <if test="applyId != null and applyId != '' ">
- and us.apply_id = #{applyId}
- </if>
- <if test="studentType != null and studentType != '' ">
- and us.student_type = #{studentType}
- </if>
- <if test="examStatus != null ">
- and us.exam_status = #{examStatus}
- </if>
- <if test="examExpend != null ">
- and us.exam_expend is NOT NULL
- </if>
- <if test="beforeExpend != null ">
- and us.before_expend is NOT NULL
- </if>
- <if test="beforeId != null and canBefore == null">
- and us.before_id =#{beforeId}
- </if>
- <if test="exceedExamExpend != null and exceedExamExpend == 1">
- and us.exam_expend = 1
- </if>
- <if test="exceedExamExpend != null and exceedExamExpend == 2">
- and (us.exam_expend is null or us.exam_expend = 0)
- </if>
- <if test="exceed != null ">
- and unix_timestamp(now()) > us.apply_site_exam_time and us.exam_expend is NULL and us.subscribe_status = 1
- </if>
- <if test="majorId != null and majorId != '' ">
- and (SELECT m.id FROM goods g LEFT JOIN major m on g.major_id= m.id where us.goods_id = g.goods_id) = #{majorId}
- </if>
- <if test="realname != null and realname != '' ">
- and (SELECT u.realname FROM `user` u where us.user_id = u.user_id) like concat('%', #{realname}, '%')
- </if>
- order by us.create_time desc
- </select>
- <select id="selectGoodsName" parameterType="string" resultType="String">
- SELECT g.goods_name FROM goods g where g.`code`=#{code} and g.status = 1
- </select>
- <select id="selectGoodsId" parameterType="string" resultType="Long">
- SELECT g.goods_id FROM goods g where g.`code`=#{code} and g.status = 1
- </select>
- <select id="selectUserId" parameterType="map" resultType="Long">
- SELECT u.user_id FROM `user` u where u.realname=#{userName} and u.id_card=#{idCard}
- </select>
- <select id="selectBeforeId" parameterType="map" resultType="Long">
- SELECT eb.before_id FROM exam_before eb where eb.before_name=#{beforeName} and eb.status = 1
- </select>
- <select id="findApplyId" parameterType="map" resultType="Long">
- SELECT ea.apply_id FROM exam_apply ea where ea.apply_name=#{applyName} and ea.status != -1
- </select>
- <select id="selectApplyId" parameterType="map" resultType="Long">
- SELECT ea.apply_id FROM exam_apply ea where ea.apply_name=#{applyName} and ea.status != -1
- </select>
- <select id="selectSubscribeId" parameterType="map" resultType="Long">
- SELECT
- us.subscribe_id
- FROM
- user_subscribe us
- WHERE 1=1
- and us.subscribe_status =1
- and us.apply_id = #{applyId}
- and us.goods_id=#{goodsId}
- and us.user_id = #{userId}
- LIMIT 1
- </select>
- <select id="selectSubscribeUpdateId" parameterType="map" resultMap="UserSubscribeVo">
- SELECT
- us.*
- FROM
- user_subscribe us
- WHERE 1=1
- and us.subscribe_status =1
- and us.apply_id = #{applyId}
- and us.goods_id=#{goodsId}
- and us.user_id = #{userId}
- and us.apply_site_exam_time = #{applySiteExamTime}
- and us.apply_site_start_time = #{applySiteStartTime}
- and us.apply_site_end_time = #{applySiteEndTime}
- and us.apply_site_address = #{applySiteAddress}
- LIMIT 1
- </select>
- <select id="selectAddSubscribeId" parameterType="map" resultType="Long">
- SELECT
- us.subscribe_id
- FROM
- user_subscribe us
- WHERE 1=1
- and ((us.subscribe_status =1 and us.exam_status =0) or us.result = 1)
- and us.apply_id = #{applyId}
- and us.goods_id=#{goodsId}
- and us.user_id = #{userId}
- limit 1
- </select>
- <select id="queryBusinessId" parameterType="map" resultType="Long">
- SELECT
- COUNT( 1 )
- FROM
- user_subscribe us
- LEFT JOIN exam_apply ea ON ea.apply_id = us.apply_id
- LEFT JOIN exam_apply_goods eag on ea.apply_id = eag.apply_id
- LEFT JOIN goods g on eag.goods_id = g.goods_id
- where 1=1
- AND g.business_id = #{businessId}
- AND us.subscribe_id = #{subscribeId}
- </select>
- <select id="timeSend" resultMap="UserSubscribeVo">
- SELECT
- * ,
- (SELECT g.business_id FROM goods g where g.goods_id = us.goods_id) as business_id
- FROM
- user_subscribe us
- WHERE us.subscribe_status = 1
- and unix_timestamp(now())+86400 > us.apply_site_exam_time
- and unix_timestamp(now()) < us.apply_site_exam_time
- and (SELECT COUNT(1) FROM inform_remind ir LEFT JOIN inform_remind_business irb on ir.id = irb.remind_id where ir.id=16 and (SELECT g.business_id FROM goods g where g.goods_id = us.goods_id) = irb.business_id) > 0
- </select>
- <select id="sendExamSucceed" parameterType="map" resultType="Long">
- SELECT
- COUNT( 1 )
- FROM
- inform_remind ir
- LEFT JOIN inform_remind_business irb on irb.remind_id =ir.id
- LEFT JOIN goods g on g.business_id = irb.business_id
- where 1=1
- and g.goods_id = #{goodsId}
- </select>
- <select id="listSubscribeByUser" parameterType="com.zhongzheng.modules.user.bo.UserSubscribeQueryBo" resultMap="UserSubscribeVo">
- SELECT
- us.user_id,
- u.realname,
- u.id_card
- FROM
- ( SELECT user_id FROM user_subscribe GROUP BY user_id ) us
- LEFT JOIN `user` u ON us.user_id = u.user_id
- WHERE
- 1 =1
- <if test="searchKey != null and searchKey != '' ">
- and (u.realname like concat('%', #{searchKey}, '%') or u.id_card like concat('%', #{searchKey}, '%'))
- </if>
- </select>
- <select id="getRecentExam" parameterType="com.zhongzheng.modules.user.bo.UserSubscribeQueryBo" resultMap="UserSubscribeVo">
- SELECT
- us.*
- FROM
- user_subscribe us
- WHERE
- 1 =1
- AND us.user_id = #{userId}
- AND us.subscribe_status = 1
- AND LEFT(us.apply_site_start_time,2)*3600+RIGHT(us.apply_site_start_time,2)*60+us.apply_site_exam_time > unix_timestamp(now())
- ORDER by us.apply_site_exam_time limit 1
- </select>
- </mapper>
|