select id, rescue_id, driver_id, driver_accept, driver_reject_reason, create_time, creator, update_time, updater from rescue_driver_info
and rescue_id = #{rescueId}
and driver_id = #{driverId}
and driver_accept = #{driverAccept}
and driver_reject_reason = #{driverRejectReason}
where id = #{id}
insert into rescue_driver_info
id,
rescue_id,
driver_id,
driver_accept,
driver_reject_reason,
#{id},
#{rescueId},
#{driverId},
#{driverAccept},
#{driverRejectReason},
update rescue_driver_info
rescue_id = #{rescueId},
driver_id = #{driverId},
driver_accept = #{driverAccept},
driver_reject_reason = #{driverRejectReason},
create_time = #{createTime},
creator = #{creator},
update_time = #{updateTime},
updater = #{updater},
where id = #{id}
delete from rescue_driver_info where id = #{id}
delete from rescue_driver_info where id in
#{id}
SELECT
ri.*,rdi.id as rescueDriverId
FROM
`rescue_info` ri
INNER JOIN rescue_driver_info rdi ON ri.id = rdi.rescue_id AND rdi.driver_accept = '2'
WHERE
ri.deleted = 0 and
rdi.driver_id =#{driverId} and ri.rescue_status = '2'
and ri.driver_id is null
ORDER BY rdi.create_time desc
SELECT
ri.*,rdi.id as rescueDriverId
FROM
`rescue_info` ri
INNER JOIN rescue_driver_info rdi ON ri.id = rdi.rescue_id AND rdi.driver_accept = '2' AND rdi.deleted = '0'
WHERE
ri.deleted = '0' and
ri.is_revoke = '0' and
rdi.driver_id =#{driverId} and ri.rescue_status = '2'
and ri.driver_id is null
ORDER BY rdi.create_time desc
SELECT
ri.*,roi.set_money
FROM
`rescue_info` ri
left join rescue_order_info roi on ri.id = roi.rescue_info_id
WHERE
ri.driver_id =#{driverId}
and ri.rescue_status = #{rescueStatus}
and (ri.rescue_status = '5' or ri.rescue_status = '6')
ORDER BY ri.create_time desc
SELECT
ri.*,roi.set_money
FROM
`rescue_info` ri
left join rescue_order_info roi on ri.id = roi.rescue_info_id AND roi.deleted = '0'
WHERE
ri.deleted = '0' and
ri.driver_id =#{map.driverId}
and ri.rescue_status = #{map.rescueStatus}
and (ri.rescue_status = '4' or ri.rescue_status = '5' or ri.rescue_status = '6')
and (ri.connection_name like concat('%', #{map.connectionName}, '%')
or ri.connection_phone like concat('%', #{map.connectionName}, '%')
or ri.license_num like concat('%', #{map.connectionName}, '%')
or ri.car_owner like concat('%', #{map.connectionName}, '%')
or ri.car_owner_phone like concat('%', #{map.connectionName}, '%'))
ORDER BY ri.create_time desc
SELECT
count(1)
FROM
`rescue_driver_info` rdi
INNER JOIN rescue_info ri on rdi.rescue_id = ri.id
where rdi.deleted = 0 and ri.is_revoke = 0 and rdi.driver_accept ='2' and rdi.driver_id =#{driverId} and ri.rescue_status = '2' and ri.driver_id is null
SELECT
rdi.id AS rescueDriverId,
rdi.rescue_id AS rescueId,
di.id,
cs.name AS userName,
di.phonenumber,
COALESCE(primary_car.car_id, secondary_car.car_id) AS driverCarId,
COALESCE(primary_car.rescue_car_num, secondary_car.rescue_car_num) AS driverCarNum,
COALESCE(primary_car.car_category, secondary_car.car_category) AS driverCarCategory
FROM rescue_driver_info rdi
INNER JOIN driver_info di ON rdi.driver_id = di.id AND di.deleted = 0
INNER JOIN company_staff cs ON di.user_id = cs.user_id AND cs.deleted = 0
LEFT JOIN (
SELECT rdcr.driver_id, rdcr.car_id, rci.rescue_car_num, rci.car_category
FROM rescue_driver_car_relation rdcr
INNER JOIN rescue_car_info rci ON rdcr.car_id = rci.id AND rci.deleted = 0
WHERE rdcr.is_primary = 1 AND rdcr.deleted = 0
) primary_car ON di.id = primary_car.driver_id
LEFT JOIN (
SELECT rdcr1.driver_id, rdcr1.car_id, rci1.rescue_car_num, rci1.car_category
FROM rescue_driver_car_relation rdcr1
INNER JOIN rescue_car_info rci1 ON rdcr1.car_id = rci1.id AND rci1.deleted = 0
WHERE rdcr1.is_primary = 0 AND rdcr1.deleted = 0
AND rdcr1.id = (
SELECT MIN(rdcr2.id)
FROM rescue_driver_car_relation rdcr2
WHERE rdcr2.driver_id = rdcr1.driver_id
AND rdcr2.is_primary = 0
AND rdcr2.deleted = 0
)
) secondary_car ON di.id = secondary_car.driver_id AND primary_car.driver_id IS NULL
WHERE rdi.rescue_id = #{rescueId}
AND rdi.deleted = 0
AND (primary_car.car_id IS NOT NULL OR secondary_car.car_id IS NOT NULL)
ORDER BY rdi.rescue_id, di.id;