| <?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.system.dao.TOrderTaxiMapper"> | 
|   | 
|     <!-- 通用查询映射结果 --> | 
|     <resultMap id="BaseResultMap" type="com.stylefeng.guns.modular.system.model.TOrderTaxi"> | 
|         <id column="id" property="id" /> | 
|         <result column="userId" property="userId" /> | 
|         <result column="driverId" property="driverId" /> | 
|         <result column="carId" property="carId" /> | 
|         <result column="orderNum" property="orderNum" /> | 
|         <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="endLon" property="endLon" /> | 
|         <result column="startAddress" property="startAddress" /> | 
|         <result column="endLat" property="endLat" /> | 
|         <result column="endAddress" property="endAddress" /> | 
|         <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="parkMoney" property="parkMoney" /> | 
|         <result column="roadTollMoney" property="roadTollMoney" /> | 
|         <result column="tipMoney" property="tipMoney" /> | 
|         <result column="redPacketMoney" property="redPacketMoney" /> | 
|         <result column="couponMoney" property="couponMoney" /> | 
|         <result column="redPacketId" property="redPacketId" /> | 
|         <result column="couponId" property="couponId" /> | 
|         <result column="companyId" property="companyId" /> | 
|         <result column="payMoney" property="payMoney" /> | 
|         <result column="substitute" property="substitute" /> | 
|         <result column="passengers" property="passengers" /> | 
|         <result column="passengersPhone" property="passengersPhone" /> | 
|         <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="orderType" property="orderType" /> | 
|         <result column="orderSource" property="orderSource" /> | 
|         <result column="invoiceId" property="invoiceId" /> | 
|         <result column="isReassign" property="isReassign" /> | 
|     </resultMap> | 
|   | 
|     <!-- 通用查询结果列 --> | 
|     <sql id="Base_Column_List"> | 
|         id, userId, driverId, carId, orderNum, placementLon, placementLat, placementAddress, startLon, startLat, endLon, startAddress, endLat, endAddress, boardingLon, boardingLat, boardingAddress, boardingTime, getoffLon, getoffLat, getoffAddress, getoffTime, mileage, payManner, payType, orderMoney, travelMoney, parkMoney, roadTollMoney, tipMoney, redPacketMoney, couponMoney, redPacketId, couponId, companyId, payMoney, substitute, passengers, passengersPhone, state, insertTime, travelTime, snatchOrderTime, setOutTime, arriveTime, startServiceTime, endServiceTime, orderType, orderSource, invoiceId, isReassign | 
|     </sql> | 
|   | 
|     <!--根据条件查询出租车订单列表--> | 
|     <select id="getTaxiOrderList" resultType="map" parameterType="com.baomidou.mybatisplus.plugins.Page"> | 
|         SELECT * FROM (SELECT ui.nickName as userName,ui.phone as userPhone,CONCAT(di.firstName, ' ', di.lastName,'-',di.phone) as driver,CONCAT(cb.`name`,'-',ci.carLicensePlate) as car, | 
|         ot.* FROM t_order_taxi as ot | 
|         LEFT JOIN t_user as ui on ui.id = ot.userId | 
|         LEFT JOIN t_driver as di on di.id = ot.driverId | 
|         LEFT JOIN t_car as ci on ci.id= ot.carId | 
|         LEFT JOIN t_car_brand as cb on cb.id = ci.carBrandId) as o | 
|         <where> | 
|             o.isDelete = 1 and o.type = 1 | 
|             <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|                 AND (o.insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|             </if> | 
|             <if test="orderNum != null and orderNum != ''"> | 
|                 and o.orderNum  LIKE CONCAT('%',#{orderNum},'%') | 
|             </if> | 
|             <if test="orderSource != null and orderSource != ''"> | 
|                 and o.orderSource = #{orderSource} | 
|             </if> | 
|             <if test="userName != null and userName != ''"> | 
|                 and o.userName  LIKE CONCAT('%',#{userName},'%') | 
|             </if> | 
|             <if test="userPhone != null and userPhone != ''"> | 
|                 and o.userPhone  LIKE CONCAT('%',#{userPhone},'%') | 
|             </if> | 
|             <if test="passengers != null and passengers != ''"> | 
|                 and o.passengers  LIKE CONCAT('%',#{passengers},'%') | 
|             </if> | 
|             <if test="passengersPhone != null and passengersPhone != ''"> | 
|                 and o.passengersPhone  LIKE CONCAT('%',#{passengersPhone},'%') | 
|             </if> | 
|             <if test="driver != null and driver != ''"> | 
|                 and o.driver  LIKE CONCAT('%',#{driver},'%') | 
|             </if> | 
|             <if test="state != null and state != ''"> | 
|                 and o.state = #{state} | 
|             </if> | 
|             <if test="roleType != null and roleType != '' and roleType == 2"> | 
|                 and (o.companyId = #{nowUserId} or FIND_IN_SET(o.companyId,(SELECT GROUP_CONCAT(id) as ids FROM t_company where superiorId = #{nowUserId} GROUP BY superiorId))) | 
|             </if> | 
|             <if test="roleType != null and roleType != '' and roleType == 3"> | 
|                 and o.companyId = #{nowUserId} | 
|             </if> | 
|         </where> | 
|         order by o.id desc | 
|     </select> | 
|   | 
|     <!--根据出租车订单ID获取出租车订单详情--> | 
|     <select id="getTaxiOrderDetailById" resultType="map"> | 
|         SELECT | 
|         DATE_FORMAT(ot.insertTime,'%Y-%m-%d %H:%i') as insertTimeStr, | 
|         DATE_FORMAT(ot.travelTime,'%Y-%m-%d %H:%i') as travelTimeStr, | 
|         DATE_FORMAT(ot.boardingTime,'%Y-%m-%d %H:%i') as boardingTimeStr, | 
|         DATE_FORMAT(ot.getoffTime,'%Y-%m-%d %H:%i') as getoffTimeStr, | 
|         case when ot.orderSource = 1 then 'APP下单' | 
|         when ot.orderSource = 2 then '扫码下单' | 
|         when ot.orderSource = 3 then '小程序下单' | 
|         when ot.orderSource = 4 then '司机下单' | 
|         when ot.orderSource = 5 then '调度下单' else '' end orderSourceStr, | 
|         ui.nickName as userName,ui.phone as userPhone, | 
|         case when ot.payType = 1 then '微信' | 
|         when ot.payType = 2 then '支付宝' | 
|         when ot.payType = 3 then '余额' else '' end as payTypeStr, | 
|         CONCAT(di.firstName, ' ', di.lastName,'-',di.phone) as driver, | 
|         CONCAT(cb.`name`,'-',ci.carLicensePlate) as car, | 
|         cc.`name` as companyName,ot.* | 
|          FROM t_order_taxi as ot | 
|         LEFT JOIN t_user as ui on ui.id = ot.userId | 
|         LEFT JOIN t_driver as di on di.id = ot.driverId | 
|         LEFT JOIN t_car as ci on ci.id= ot.carId | 
|         LEFT JOIN t_car_brand as cb on cb.id = ci.carBrandId | 
|         LEFT JOIN t_company as cc on cc.id = ot.companyId | 
|         where ot.id = #{orderId} | 
|     </select> | 
|   | 
|     <!--根据条件查询可被选择的出租车司机列表--> | 
|     <select id="getCanSelectTaxiDriverList" resultType="map" parameterType="com.baomidou.mybatisplus.plugins.Page"> | 
|         SELECT dd.*,c1.name as companyName,c2.name as franchiseeName from t_driver AS dd | 
|         LEFT JOIN t_company as c1 on c1.id = dd.companyId | 
|         LEFT JOIN t_company as c2 on c2.id = dd.franchiseeId | 
|         LEFT JOIN (SELECT * from t_driver_service where type = 2) as ds on ds.driverId = dd.id | 
|         <where> | 
|             (dd.companyId = #{companyId} or dd.franchiseeId = #{companyId}) and dd.authState = 2 and dd.state = 2 and (ds.id is not null ) and (dd.carId is not null) | 
|             <if test="name != null and name != ''"> | 
|                 and CONCAT(dd.firstName, ' ', dd.lastName) LIKE CONCAT('%',#{name},'%') | 
|             </if> | 
|             <if test="phone != null and phone != ''"> | 
|                 and dd.phone LIKE CONCAT('%',#{phone},'%') | 
|             </if> | 
|         </where> | 
|         order by dd.id desc | 
|     </select> | 
|   | 
|     <!--查询所有订单条数--> | 
|     <select id="getAllOrderNum" resultType="java.lang.Integer"> | 
|         SELECT IFNULL(SUM(num),0) as value FROM ( | 
|         (SELECT IFNULL(COUNT(id),0) as num FROM t_order_taxi where FIND_IN_SET(state,'8,9') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         union all | 
|         (SELECT IFNULL(COUNT(id),0) as num FROM t_order_chartered_car where FIND_IN_SET(state,'2') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         union all | 
|         (SELECT IFNULL(COUNT(id),0) as num FROM t_order_cross_city where FIND_IN_SET(state,'8,9') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         union all | 
|         (SELECT IFNULL(COUNT(id),0) as num FROM t_order_logistics where FIND_IN_SET(state,'8,9') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         union all | 
|         (SELECT IFNULL(COUNT(id),0) as num FROM t_order_private_car where FIND_IN_SET(state,'8,9') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         ) as o | 
|     </select> | 
|   | 
|     <!--查询所有总交易金额--> | 
|     <select id="getAllTradeMoney" resultType="java.lang.Double"> | 
|         SELECT IFNULL(SUM(num),0) as value FROM ( | 
|         (SELECT IFNULL(SUM(payMoney),0) as num FROM t_order_taxi where FIND_IN_SET(state,'8,9') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         union all | 
|         (SELECT IFNULL(SUM(payMoney),0) as num FROM t_order_cross_city where FIND_IN_SET(state,'8,9') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         union all | 
|         (SELECT IFNULL(SUM(payMoney),0) as num FROM t_order_logistics where FIND_IN_SET(state,'8,9') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         union all | 
|         (SELECT IFNULL(SUM(payMoney),0) as num FROM t_order_private_car where FIND_IN_SET(state,'8,9') | 
|         <if test="companyId != null and companyId != ''"> | 
|             and companyId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|         ) | 
|         ) as o | 
|     </select> | 
|   | 
|     <!--查询所有总收益--> | 
|     <select id="getAllIncomeMoney" resultType="java.lang.Double"> | 
|         SELECT IFNULL(SUM(money),0) as value FROM t_income where userType = 1 | 
|         <if test="companyId != null and companyId != ''"> | 
|             and objectId = #{companyId} | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             AND (insertTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|     </select> | 
|   | 
|   | 
|   | 
| </mapper> |