270 lines
12 KiB
XML
270 lines
12 KiB
XML
<?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="cn.iocoder.yudao.module.tickets.mapper.DlRepairTicketsMapper">
|
|
|
|
<resultMap id="BaseResultMap" type="cn.iocoder.yudao.module.tickets.vo.DlRepairTicketsRespVO">
|
|
<id property="id" column="id" jdbcType="VARCHAR"/>
|
|
<result property="ticketNo" column="ticket_no" jdbcType="VARCHAR"/>
|
|
<result property="repairType" column="repair_type" jdbcType="VARCHAR"/>
|
|
<result property="userId" column="user_id" jdbcType="VARCHAR"/>
|
|
<result property="userName" column="user_name" jdbcType="VARCHAR"/>
|
|
<result property="userMobile" column="user_mobile" jdbcType="VARCHAR"/>
|
|
<result property="carId" column="car_id" jdbcType="VARCHAR"/>
|
|
<result property="carNo" column="car_no" jdbcType="VARCHAR"/>
|
|
<result property="carVin" column="car_vin" jdbcType="VARCHAR"/>
|
|
<result property="carBrandId" column="car_brand_id" jdbcType="VARCHAR"/>
|
|
<result property="carBrandName" column="car_brand_name" jdbcType="VARCHAR"/>
|
|
<result property="carBrandType" column="car_brand_type" jdbcType="VARCHAR"/>
|
|
<result property="adviserId" column="adviser_id" jdbcType="VARCHAR"/>
|
|
<result property="adviserName" column="adviser_name" jdbcType="VARCHAR"/>
|
|
<result property="payType" column="pay_type" jdbcType="VARCHAR"/>
|
|
<result property="repairAdvice" column="repair_advice" jdbcType="VARCHAR"/>
|
|
<result property="qualityMileage" column="quality_mileage" jdbcType="VARCHAR"/>
|
|
<result property="qualityDay" column="quality_day" jdbcType="VARCHAR"/>
|
|
<result property="endCheck" column="end_check" jdbcType="VARCHAR"/>
|
|
<result property="partDisposal" column="part_disposal" jdbcType="VARCHAR"/>
|
|
<result property="remark" column="remark" jdbcType="VARCHAR"/>
|
|
<result property="ticketType" column="ticket_type" jdbcType="VARCHAR"/>
|
|
<result property="corpId" column="corp_id" jdbcType="VARCHAR"/>
|
|
<result property="deptId" column="dept_id" jdbcType="BIGINT"/>
|
|
<result property="count" column="count"/>
|
|
<result property="projectPrice" column="project_price"/>
|
|
<result property="partPrice" column="part_price"/>
|
|
<result property="otherPrice" column="other_price"/>
|
|
<result property="totalPrice" column="total_price"/>
|
|
<result property="ticketsStatus" column="tickets_status"/>
|
|
<result property="createTime" column="create_time"/>
|
|
<result property="inTime" column="in_time" />
|
|
<result property="outTime" column="out_time" />
|
|
<result property="cost" column="cost" />
|
|
<result property="profit" column="profit" />
|
|
<result property="partStatus" column="part_status" />
|
|
<result property="ticketsWorkStatus" column="tickets_work_status" />
|
|
<result property="isFinish" column="is_finish" />
|
|
<result property="nowRepairId" column="now_repair_id" />
|
|
<result property="nowRepairName" column="now_repair_name" />
|
|
<association property="booking" javaType="cn.iocoder.yudao.module.booking.entity.DlRepairBooking" select="selectBookingById" column="id"/>
|
|
<collection property="itemList" column="id" ofType="cn.iocoder.yudao.module.tickets.entity.DlRepairTitem" columnPrefix="item_">
|
|
<id property="id" column="id" jdbcType="VARCHAR"/>
|
|
<result property="ticketId" column="ticket_id" />
|
|
<result property="itemName" column="item_name" />
|
|
<result property="itemCount" column="item_count" />
|
|
<result property="itemUnit" column="item_unit" />
|
|
<result property="itemPrice" column="item_price" />
|
|
<result property="itemDiscount" column="item_discount" />
|
|
<result property="itemMoney" column="item_money" />
|
|
<result property="repairIds" column="repair_ids" />
|
|
<result property="repairNames" column="repair_names" />
|
|
<result property="saleId" column="sale_id" />
|
|
<result property="saleName" column="sale_name" />
|
|
<result property="itemType" column="item_type" />
|
|
<result property="projectId" column="project_id" />
|
|
<result property="partId" column="part_id" />
|
|
<result property="otherId" column="other_id" />
|
|
<result property="itemTypeId" column="item_type_id" />
|
|
<result property="itemStatus" column="item_status" />
|
|
<result property="remark" column="remark" />
|
|
</collection>
|
|
</resultMap>
|
|
|
|
<sql id="Base_SQL">
|
|
select id,
|
|
ticket_no,
|
|
repair_type,
|
|
user_id,
|
|
user_name,
|
|
user_mobile,
|
|
car_id,
|
|
car_no,
|
|
car_vin,
|
|
car_brand_id,
|
|
car_brand_name,
|
|
car_brand_type,
|
|
adviser_id,
|
|
adviser_name,
|
|
pay_type,
|
|
repair_advice,
|
|
quality_mileage,
|
|
quality_day,
|
|
end_check,
|
|
part_disposal,
|
|
remark,
|
|
ticket_type,
|
|
corp_id,
|
|
dept_id,
|
|
count,
|
|
project_price,
|
|
part_price,
|
|
other_price,
|
|
total_price,
|
|
tickets_status,
|
|
create_time,
|
|
in_time,
|
|
out_time,
|
|
cost,
|
|
profit,
|
|
part_status,
|
|
tickets_work_status,
|
|
is_finish,
|
|
now_repair_id,
|
|
now_repair_name
|
|
from dl_repair_tickets drt
|
|
where drt.deleted = '0'
|
|
</sql>
|
|
<select id="selectBookingById" resultType="cn.iocoder.yudao.module.booking.entity.DlRepairBooking">
|
|
SELECT * FROM dl_repair_booking WHERE tickets_id = #{id}
|
|
</select>
|
|
<select id="getTicketsPage" resultMap="BaseResultMap">
|
|
<include refid="Base_SQL"/>
|
|
<if test="map.ticketsStatus != null and map.ticketsStatus != '' and map.ticketsStatus != '01'">
|
|
and drt.tickets_status = #{map.ticketsStatus}
|
|
</if>
|
|
<if test="map.ticketsStatus != null and map.ticketsStatus != '' and map.ticketsStatus == '01'">
|
|
and (drt.tickets_status = #{map.ticketsStatus} or drt.tickets_status = '06')
|
|
</if>
|
|
<if test="map.ticketNo != null and map.ticketNo != ''">
|
|
and (
|
|
drt.ticket_no like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.car_no like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.user_name like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.user_mobile like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.remark like concat('%', #{map.ticketNo}, '%')
|
|
)
|
|
</if>
|
|
<if test="map.searchTimeArray != null and map.searchTimeArray.length > 0">
|
|
and drt.create_time between #{map.searchTimeArray[0]} and #{map.searchTimeArray[1]}
|
|
</if>
|
|
<if test="map.repairType != null and map.repairType != ''">
|
|
and drt.repair_type = #{map.repairType}
|
|
</if>
|
|
<if test="map.corpId != null and map.corpId != ''">
|
|
and drt.corp_id = #{map.corpId}
|
|
</if>
|
|
<if test="map.userId != null and map.userId != ''">
|
|
and drt.user_id = #{map.userId}
|
|
</if>
|
|
<if test="map.ticketsWorkStatus != null and map.ticketsWorkStatus != ''">
|
|
and drt.tickets_work_status = #{map.ticketsWorkStatus}
|
|
</if>
|
|
order by drt.create_time desc
|
|
</select>
|
|
|
|
<select id="getPageType" resultMap="BaseResultMap">
|
|
select drt.*,
|
|
drti.id AS item_id,
|
|
drti.ticket_id AS item_ticket_id,
|
|
drti.item_name AS item_item_name,
|
|
drti.item_count AS item_item_count,
|
|
drti.item_unit AS item_item_unit,
|
|
drti.item_price AS item_item_price,
|
|
drti.item_discount AS item_item_discount,
|
|
drti.item_money AS item_item_money,
|
|
drti.repair_ids AS item_repair_ids,
|
|
drti.repair_names AS item_repair_names,
|
|
drti.sale_id AS item_sale_id,
|
|
drti.sale_name AS item_sale_name,
|
|
drti.item_type AS item_item_type,
|
|
drti.project_id AS item_project_id,
|
|
drti.part_id AS item_part_id,
|
|
drti.other_id AS item_other_id,
|
|
drti.item_type_id AS item_type_id,
|
|
drti.item_status AS item_item_status,
|
|
drti.remark AS item_remark
|
|
from dl_repair_tickets drt
|
|
left join dl_repair_titem drti
|
|
on drt.id = drti.ticket_id AND drti.deleted = '0'
|
|
where drt.deleted = '0'
|
|
<if test="map.ticketNo != null and map.ticketNo != ''">
|
|
and (
|
|
drt.ticket_no like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.car_no like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.user_name like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.user_mobile like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.remark like concat('%', #{map.ticketNo}, '%')
|
|
)
|
|
</if>
|
|
<if test="map.searchTimeArray != null and map.searchTimeArray.length > 0">
|
|
and drt.create_time between #{map.searchTimeArray[0]} and #{map.searchTimeArray[1]}
|
|
</if>
|
|
<if test="map.adviserId != null and map.adviserId != ''">
|
|
and drt.adviser_id = #{map.adviserId}
|
|
</if>
|
|
<if test="map.isFinish != null and map.isFinish != ''">
|
|
and drt.is_finish = #{map.isFinish}
|
|
</if>
|
|
<if test="map.userIds != null and map.userIds.size > 0">
|
|
and (drt.tickets_status = '05')
|
|
and (drt.now_repair_id in
|
|
<foreach collection="map.userIds" item="item" index="index" open="(" separator="," close=")">
|
|
#{item}
|
|
</foreach>
|
|
)
|
|
</if>
|
|
order by drt.create_time desc
|
|
</select>
|
|
|
|
<select id="getPageTypeAll" resultMap="BaseResultMap">
|
|
select drt.*,
|
|
drti.id AS item_id,
|
|
drti.ticket_id AS item_ticket_id,
|
|
drti.item_name AS item_item_name,
|
|
drti.item_count AS item_item_count,
|
|
drti.item_unit AS item_item_unit,
|
|
drti.item_price AS item_item_price,
|
|
drti.item_discount AS item_item_discount,
|
|
drti.item_money AS item_item_money,
|
|
drti.repair_ids AS item_repair_ids,
|
|
drti.repair_names AS item_repair_names,
|
|
drti.sale_id AS item_sale_id,
|
|
drti.sale_name AS item_sale_name,
|
|
drti.item_type AS item_item_type,
|
|
drti.project_id AS item_project_id,
|
|
drti.part_id AS item_part_id,
|
|
drti.other_id AS item_other_id,
|
|
drti.item_type_id AS item_type_id,
|
|
drti.item_status AS item_item_status,
|
|
drti.remark AS item_remark
|
|
from dl_repair_tickets drt
|
|
left join dl_repair_titem drti
|
|
on drt.id = drti.ticket_id AND drti.deleted = '0'
|
|
where drt.deleted = '0'
|
|
<if test="map.ticketNo != null and map.ticketNo != ''">
|
|
and (
|
|
drt.ticket_no like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.car_no like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.user_name like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.user_mobile like concat('%', #{map.ticketNo}, '%')
|
|
or
|
|
drt.remark like concat('%', #{map.ticketNo}, '%')
|
|
)
|
|
</if>
|
|
<if test="map.searchTimeArray != null and map.searchTimeArray.length > 0">
|
|
and drt.create_time between #{map.searchTimeArray[0]} and #{map.searchTimeArray[1]}
|
|
</if>
|
|
<if test="map.adviserId != null and map.adviserId != ''">
|
|
and drt.adviser_id = #{map.adviserId}
|
|
</if>
|
|
<if test="map.userIds != null and map.userIds.size > 0">
|
|
and (
|
|
<foreach item="item" collection="map.userIds" index="index" open="" separator="or" close="">
|
|
find_in_set(#{item}, drt.now_repair_id) > 0
|
|
</foreach>
|
|
)
|
|
</if>
|
|
order by drt.create_time desc
|
|
</select>
|
|
</mapper>
|