| <?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.stylefeng.guns.modular.smallLogistics.dao.OrderLogisticsMapper"> | 
|   | 
|     <!-- 通用查询映射结果 --> | 
|     <resultMap id="BaseResultMap" type="com.stylefeng.guns.modular.smallLogistics.model.OrderLogistics"> | 
|         <id column="id" property="id"/> | 
|         <result column="type" property="type"/> | 
|         <result column="userId" property="userId"/> | 
|         <result column="driverId" property="driverId"/> | 
|         <result column="carId" property="carId"/> | 
|         <result column="orderNum" property="orderNum"/> | 
|         <result column="cargoType" property="cargoType"/> | 
|         <result column="urgent" property="urgent"/> | 
|         <result column="cargoNumber" property="cargoNumber"/> | 
|         <result column="userImg" property="userImg"/> | 
|         <result column="driverImg" property="driverImg"/> | 
|         <result column="remark" property="remark"/> | 
|         <result column="placementLon" property="placementLon"/> | 
|         <result column="placementLat" property="placementLat"/> | 
|         <result column="placementAddress" property="placementAddress"/> | 
|         <result column="startLon" property="startLon"/> | 
|         <result column="startLat" property="startLat"/> | 
|         <result column="startAddress" property="startAddress"/> | 
|         <result column="endLon" property="endLon"/> | 
|         <result column="endLat" property="endLat"/> | 
|         <result column="endAddress" property="endAddress"/> | 
|         <result column="recipient" property="recipient"/> | 
|         <result column="recipientPhone" property="recipientPhone"/> | 
|         <result column="boardingLon" property="boardingLon"/> | 
|         <result column="boardingLat" property="boardingLat"/> | 
|         <result column="boardingAddress" property="boardingAddress"/> | 
|         <result column="boardingTime" property="boardingTime"/> | 
|         <result column="getoffLon" property="getoffLon"/> | 
|         <result column="getoffLat" property="getoffLat"/> | 
|         <result column="getoffAddress" property="getoffAddress"/> | 
|         <result column="getoffTime" property="getoffTime"/> | 
|         <result column="mileage" property="mileage"/> | 
|         <result column="payManner" property="payManner"/> | 
|         <result column="payType" property="payType"/> | 
|         <result column="orderMoney" property="orderMoney"/> | 
|         <result column="travelMoney" property="travelMoney"/> | 
|         <result column="tipMoney" property="tipMoney"/> | 
|         <result column="holidayFee" property="holidayFee"/> | 
|         <result column="redPacketMoney" property="redPacketMoney"/> | 
|         <result column="couponMoney" property="couponMoney"/> | 
|         <result column="redPacketId" property="redPacketId"/> | 
|         <result column="couponId" property="couponId"/> | 
|         <result column="discount" property="discount"/> | 
|         <result column="discountMoney" property="discountMoney"/> | 
|         <result column="activityId" property="activityId"/> | 
|         <result column="taxiCardId" property="taxiCardId"/> | 
|         <result column="userTaxiCardId" property="userTaxiCardId"/> | 
|         <result column="discountAmount" property="discountAmount"/> | 
|         <result column="companyId" property="companyId"/> | 
|         <result column="payMoney" property="payMoney"/> | 
|         <result column="thankYouFee" property="thankYouFee"/> | 
|         <result column="state" property="state"/> | 
|         <result column="insertTime" property="insertTime"/> | 
|         <result column="travelTime" property="travelTime"/> | 
|         <result column="snatchOrderTime" property="snatchOrderTime"/> | 
|         <result column="setOutTime" property="setOutTime"/> | 
|         <result column="arriveTime" property="arriveTime"/> | 
|         <result column="startServiceTime" property="startServiceTime"/> | 
|         <result column="endServiceTime" property="endServiceTime"/> | 
|         <result column="orderSource" property="orderSource"/> | 
|         <result column="invoiceId" property="invoiceId"/> | 
|         <result column="trackId" property="trackId"/> | 
|         <result column="isDelete" property="isDelete"/> | 
|         <result column="telX" property="telX"/> | 
|         <result column="bindId" property="bindId"/> | 
|         <result column="pickUpCode" property="pickUpCode"/> | 
|         <result column="isReassign" property="isReassign"/> | 
|         <result column="reassignNotice" property="reassignNotice"/> | 
|         <result column="splitAllocation" property="splitAllocation"/> | 
|     </resultMap> | 
|   | 
|   | 
|   | 
|     <select id="query" resultType="OrderLogistics"> | 
| select | 
| id as id, | 
|         type as type, | 
|         userId as userId, | 
|         driverId as driverId, | 
|         carId as carId, | 
|         orderNum as orderNum, | 
|         cargoType as cargoType, | 
|         cargoNumber as cargoNumber, | 
|         remark as remark, | 
|         placementLon as placementLon, | 
|         placementLat as placementLat, | 
|         placementAddress as placementAddress, | 
|         startLon as startLon, | 
|         startLat as startLat, | 
|         startAddress as startAddress, | 
|         endLon as endLon, | 
|         endLat as endLat, | 
|         endAddress as endAddress, | 
|         recipient as recipient, | 
|         recipientPhone as recipientPhone, | 
|         boardingLon as boardingLon, | 
|         boardingLat as boardingLat, | 
|         boardingAddress as boardingAddress, | 
|         boardingTime as boardingTime, | 
|         getoffLon as getoffLon, | 
|         getoffLat as getoffLat, | 
|         getoffAddress as getoffAddress, | 
|         getoffTime as getoffTime, | 
|         mileage as mileage, | 
|         payManner as payManner, | 
|         payType as payType, | 
|         orderMoney as orderMoney, | 
|         travelMoney as travelMoney, | 
|         tipMoney as tipMoney, | 
|         redPacketMoney as redPacketMoney, | 
|         couponMoney as couponMoney, | 
|         redPacketId as redPacketId, | 
|         couponId as couponId, | 
|         discount as discount, | 
|         discountMoney as discountMoney, | 
|         activityId as activityId, | 
|         companyId as companyId, | 
|         payMoney as payMoney, | 
|         state as state, | 
|         insertTime as insertTime, | 
|         travelTime as travelTime, | 
|         snatchOrderTime as snatchOrderTime, | 
|         setOutTime as setOutTime, | 
|         arriveTime as arriveTime, | 
|         startServiceTime as startServiceTime, | 
|         endServiceTime as endServiceTime, | 
|         orderSource as orderSource, | 
|         invoiceId as invoiceId, | 
|         trackId as trackId, | 
|         isDelete as isDelete, | 
|         telX as telX, | 
|         bindId as bindId | 
|         from t_order_logistics where isDelete = 1 | 
|         <if test="null != start and null != end"> | 
|             and insertTime between #{start} and #{end} | 
|         </if> | 
|     </select> | 
|   | 
|   | 
|   | 
|     <select id="queryLogisticsNumber" resultType="int"> | 
|         select | 
|         count(id) | 
|         from t_order_logistics where isDelete = 1 and state in (1, 2, 3, 4, 5, 7) and userId = #{uid} | 
|     </select> | 
|   | 
|   | 
|     <select id="queryMyOrderList" resultType="map"> | 
|         select | 
|         id as orderId, | 
|         DATE_FORMAT(insertTime, '%Y-%m-%d %H:%i') as orderTime, | 
|         DATE_FORMAT(travelTime, '%Y-%m-%d %H:%i') as time, | 
|         endAddress as endAddress, | 
|         startAddress as startAddress, | 
|         CONCAT((if(cargoType = 1, '普通小件', '贵重物品')), 'X', cargoNumber) as cargoType, | 
|         driverId as driverId, | 
|         `type` as orderType, | 
|         state as state, | 
|         orderMoney as orderMoney, | 
|         payMoney as payMoney, | 
|         (select price from t_order_logistics_spread where orderLogisticsId = a.id) as differenceMoney, | 
|         userImg, | 
|         driverImg, | 
|         thankYouFee, | 
|         DATE_FORMAT(arriveTimeExpect, '%Y-%m-%d %H:%i') as arriveTimeExpect, | 
|         IF(endServiceTime is not null,DATE_FORMAT(endServiceTime, '%Y-%m-%d %H:%i'),'') as endServiceTime, | 
|         pickUpCode | 
|         from t_order_logistics as a where userId = #{uid} and a.type = #{type} order by insertTime desc limit #{pageNum}, #{size} | 
|     </select> | 
|   | 
|   | 
|     <select id="queryMyTravelRecord" resultType="map"> | 
|         select | 
|         (payMoney * -1) as money, | 
|         DATE_FORMAT(insertTime, '%Y-%m-%d %H:%i') as time, | 
|         if(type = 4, '同城小件物流订单', '跨城小件物流') as name, | 
|         UNIX_TIMESTAMP(insertTime) as insertTime | 
|         from t_order_logistics where (payMoney != 0 or payMoney is not null) and userId = #{uid}  order by insertTime desc | 
|     </select> | 
|   | 
|   | 
|   | 
|     <select id="queryInvoiceOrder" resultType="map"> | 
|         select | 
|         id as orderId, | 
|         DATE_FORMAT(travelTime, '%Y-%m-%d %H:%i') as time, | 
|         startAddress as startAddress, | 
|         endAddress as endAddress, | 
|         payMoney as payMoney, | 
|         if(type = 4, '同城小件物流订单', '跨城小件物流订单') as orderName, | 
|         if(invoiceId is null, 1, 2) as invoice, | 
|         unix_timestamp(insertTime) as insertTime, | 
|         `type` as orderType | 
|         from t_order_logistics where state in (9) | 
|         <if test="type == 1"> | 
|             and (invoiceId is null or invoiceId in (select id from t_invoice where state = 3)) | 
|         </if> | 
|         <if test="type == 2"> | 
|             and invoiceId in (select id from t_invoice where state = 2) | 
|         </if> | 
|         <if test="null != startTime"> | 
|             and travelTime >= #{startTime} | 
|         </if> | 
|         <if test="null != startMoney"> | 
|             and payMoney >= #{startMoney} | 
|         </if> | 
|         <if test="null != endTime"> | 
|             and  #{endTime}>= travelTime | 
|         </if> | 
|         <if test="null != endMoney"> | 
|             and   #{endMoney}>=payMoney | 
|         </if> | 
|         <if test="null !=uid"> | 
|             and userId = #{uid} | 
|         </if> | 
|         <if test="null != orderType"> | 
|             and `type` = #{orderType} | 
|         </if> | 
|     </select> | 
|   | 
|   | 
|     <select id="queryByState" resultType="com.stylefeng.guns.modular.smallLogistics.model.OrderLogistics"> | 
|         select * from t_order_logistics where isDelete = 1 and userId = #{uid} | 
|         <if test="null != state"> | 
|             and state in | 
|             <foreach collection="state" item="item" index="index" open="(" separator="," close=")"> | 
|                 #{item} | 
|             </foreach> | 
|         </if> | 
|     </select> | 
| </mapper> |