You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
543 lines
33 KiB
543 lines
33 KiB
<?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.zc.business.mapper.DcPerceivedEventsWarningMapper">
|
|
|
|
|
|
|
|
<select id="perceivedEventsWarningNum" resultType="java.lang.Integer">
|
|
select count(1) from dc_warning where warning_state=1
|
|
</select>
|
|
|
|
<select id="selectEventTypeList" resultType="com.zc.business.domain.DcEventType">
|
|
select event_type, event_name from dc_event_type
|
|
</select>
|
|
<select id="selectWarningById" resultType="com.zc.business.domain.DcWarning">
|
|
SELECT DISTINCT warning.`id`,warning.`stake_mark`, warning.`direction`,
|
|
warning.duration,
|
|
user.user_name,warning.event_cause,warning.end_time,
|
|
mark.longitude,mark.latitude,warning.lane,warning.vehicle_type vehicleType,
|
|
warning.`dept_id`,warning.`warning_state`,warning.`warning_time`,
|
|
warning.`user_id`, warning.`warning_source`,warning.`warning_level`,
|
|
warning.`remark`, warning.`create_time`,warning.`update_time`,
|
|
warning.`warning_type`,warning.`warning_subclass`,warning.`warning_title`,
|
|
warning.`other_config` FROM dc_warning AS warning
|
|
LEFT JOIN dc_stake_mark AS mark ON mark.stake_mark=warning.stake_mark and mark.direction=warning.direction
|
|
LEFT JOIN sys_user as user on user.user_id=warning.user_id
|
|
where warning.`id`=#{id}
|
|
</select>
|
|
<select id="selectPerceivedEventsList" resultType="com.zc.business.domain.DcWarning">
|
|
SELECT facility.facility_name, warning.`id`,warning.`stake_mark`, warning.`direction`,facility.facility_name,
|
|
mark.longitude,mark.latitude,warning.lane,duration,
|
|
warning.`dept_id`,warning.`warning_state`,warning.`warning_time`,
|
|
warning.`user_id`, warning.`warning_source`,warning.`warning_level`,
|
|
warning.`remark`, warning.`create_time`,warning.`update_time`,
|
|
warning.`warning_type`,warning.`warning_subclass`,warning.`warning_title`,
|
|
warning.`other_config` FROM dc_warning AS warning
|
|
left JOIN dc_stake_mark AS mark ON mark.stake_mark=warning.stake_mark and mark.direction=warning.direction
|
|
left join dc_facility as facility on facility.stake_mark=warning.stake_mark
|
|
<where>
|
|
<if test="warningSource == null || warningSource == ''"> and warning.warning_source !=6</if>
|
|
<if test="warningSource != null and warningSource != ''"> and warning.warning_source = #{warningSource}</if>
|
|
<if test="warningState != null and warningState != ''"> and warning.warning_state = #{warningState}</if>
|
|
<if test="warningType != null and warningType != ''"> and warning.warning_type = #{warningType}</if>
|
|
<if test="warningSubclass != null and warningSubclass != ''"> and warning.warning_subclass = #{warningSubclass}</if>
|
|
<if test="direction != null and direction != ''"> and warning.direction = #{direction}</if>
|
|
<if test="stakeMark != null and stakeMark != ''"> and warning.stake_mark = #{stakeMark}</if>
|
|
<if test="startTime != null and completeTime != null ">
|
|
and warning.warning_time between #{startTime} and #{completeTime}</if>
|
|
<if test="startStakeMark != null and startStakeMark != ''">
|
|
and CAST(SUBSTRING(SUBSTRING_INDEX(warning.stake_mark,'+',1),2)AS UNSIGNED)*1000
|
|
+CAST(SUBSTRING_INDEX(warning.stake_mark, '+', -1) AS UNSIGNED)>#{startStakeMark}
|
|
</if>
|
|
<if test=" endStakeMark != null and endStakeMark != '' ">
|
|
and CAST(SUBSTRING(SUBSTRING_INDEX(warning.stake_mark,'+',1),2)AS UNSIGNED)*1000
|
|
+CAST(SUBSTRING_INDEX(warning.stake_mark, '+', -1) AS UNSIGNED)<#{endStakeMark}
|
|
</if>
|
|
|
|
</where>
|
|
order by warning.warning_time desc
|
|
</select>
|
|
<select id="selectNonAutomaticWarningList" resultType="com.zc.business.domain.DcWarning">
|
|
SELECT facility.facility_name, warning.`id`,warning.`stake_mark`, warning.`direction`,facility.facility_name,
|
|
mark.longitude,mark.latitude,warning.lane,duration,
|
|
warning.`dept_id`,warning.`warning_state`,warning.`warning_time`,
|
|
warning.`user_id`, warning.`warning_source`,warning.`warning_level`,
|
|
warning.`remark`, warning.`create_time`,warning.`update_time`,
|
|
warning.`warning_type`,warning.`warning_subclass`,warning.`warning_title`,
|
|
warning.`other_config` FROM dc_warning AS warning
|
|
left JOIN dc_stake_mark AS mark ON mark.stake_mark=warning.stake_mark and mark.direction=warning.direction
|
|
left join dc_facility as facility on facility.stake_mark=warning.stake_mark
|
|
<where>
|
|
<if test="warningSource != null and warningSource != ''"> and warning.warning_source = #{warningSource}</if>
|
|
<if test="warningState != null and warningState != ''"> and warning.warning_state = #{warningState}</if>
|
|
<if test="warningType != null and warningType != ''"> and warning.warning_type = #{warningType}</if>
|
|
<if test="warningSubclass != null and warningSubclass != ''"> and warning.warning_subclass = #{warningSubclass}</if>
|
|
<if test="direction != null and direction != ''"> and warning.direction = #{direction}</if>
|
|
<if test="stakeMark != null and stakeMark != ''"> and warning.stake_mark = #{stakeMark}</if>
|
|
<if test="startTime != null and completeTime != null ">
|
|
and warning.warning_time between #{startTime} and #{completeTime}</if>
|
|
<if test="startStakeMark != null and startStakeMark != ''">
|
|
and CAST(SUBSTRING(SUBSTRING_INDEX(warning.stake_mark,'+',1),2)AS UNSIGNED)*1000
|
|
+CAST(SUBSTRING_INDEX(warning.stake_mark, '+', -1) AS UNSIGNED)>#{startStakeMark}
|
|
</if>
|
|
<if test=" endStakeMark != null and endStakeMark != '' ">
|
|
and CAST(SUBSTRING(SUBSTRING_INDEX(warning.stake_mark,'+',1),2)AS UNSIGNED)*1000
|
|
+CAST(SUBSTRING_INDEX(warning.stake_mark, '+', -1) AS UNSIGNED)<#{endStakeMark}
|
|
</if>
|
|
|
|
</where>
|
|
order by warning.warning_time desc
|
|
</select>
|
|
<select id="selectWarningList" resultType="com.zc.business.domain.DcWarning">
|
|
SELECT warning.`id`,warning.`stake_mark`, warning.`direction`,
|
|
mark.longitude,mark.latitude,warning.lane,duration,
|
|
warning.`dept_id`,warning.`warning_state`,warning.`warning_time`,
|
|
warning.`user_id`, warning.`warning_source`,warning.`warning_level`,
|
|
warning.`remark`, warning.`create_time`,warning.`update_time`,
|
|
warning.`warning_type`,warning.`warning_subclass`,warning.`warning_title`,
|
|
warning.`other_config` FROM dc_warning AS warning
|
|
left JOIN dc_stake_mark AS mark ON mark.stake_mark=warning.stake_mark and mark.direction=warning.direction
|
|
<where>
|
|
warning.warning_source!=6
|
|
<if test="warningState != null and warningState != ''"> and warning.warning_state = #{warningState}</if>
|
|
<if test="warningSubclass != null and warningSubclass != ''"> and warning.warning_subclass = #{warningSubclass}</if>
|
|
<if test="direction != null and direction != ''"> and warning.direction = #{direction}</if>
|
|
<if test="stakeMark != null and stakeMark != ''"> and warning.stake_mark = #{stakeMark}</if>
|
|
<if test="startTime != null and completeTime != null ">
|
|
and warning.warning_time between #{startTime} and #{completeTime}</if>
|
|
<if test="startStakeMark != null and startStakeMark != ''">
|
|
and CAST(SUBSTRING(SUBSTRING_INDEX(warning.stake_mark,'+',1),2)AS UNSIGNED)*1000
|
|
+CAST(SUBSTRING_INDEX(warning.stake_mark, '+', -1) AS UNSIGNED)>#{startStakeMark}
|
|
</if>
|
|
<if test=" endStakeMark != null and endStakeMark != '' ">
|
|
and CAST(SUBSTRING(SUBSTRING_INDEX(warning.stake_mark,'+',1),2)AS UNSIGNED)*1000
|
|
+CAST(SUBSTRING_INDEX(warning.stake_mark, '+', -1) AS UNSIGNED)<#{endStakeMark}
|
|
</if>
|
|
</where>
|
|
order by warning.warning_time desc
|
|
</select>
|
|
<select id="selectSectionPerceivedEventsList" resultType="hashmap">
|
|
SELECT s.section_name AS sectionName, COALESCE(w_count.number, 0) AS number2
|
|
FROM dc_road_section AS s
|
|
LEFT JOIN ( SELECT mark.section_id, COUNT(1) AS number FROM dc_warning AS w JOIN
|
|
dc_stake_mark AS mark ON mark.stake_mark = w.stake_mark AND mark.direction = w.direction
|
|
WHERE mark.stake_mark IS NOT NULL AND DATE_FORMAT(w.warning_time, '%Y-%m-%d') = DATE_FORMAT(#{warningTime}, '%Y-%m-%d')
|
|
and w.warning_source!=6
|
|
GROUP BY mark.section_id ) AS w_count ON s.id = w_count.section_id
|
|
ORDER BY number DESC;
|
|
</select>
|
|
|
|
<select id="selectSectionPerceivedNumber" resultType="java.util.HashMap">
|
|
SELECT s.section_name AS sectionName, COALESCE(w_count.number, 0) AS number2
|
|
FROM dc_road_section AS s
|
|
LEFT JOIN ( SELECT mark.section_id, COUNT(1) AS number FROM dc_warning AS w JOIN
|
|
dc_stake_mark AS mark ON mark.stake_mark = w.stake_mark AND mark.direction = w.direction
|
|
WHERE mark.stake_mark IS NOT NULL AND DATE_FORMAT(w.warning_time, '%Y-%m-%d') = DATE_FORMAT(#{warningTime}, '%Y-%m-%d')
|
|
and w.warning_source!=6
|
|
GROUP BY mark.section_id ) AS w_count ON s.id = w_count.section_id
|
|
</select>
|
|
<select id="selectDailyCumulative" resultType="java.util.HashMap">
|
|
SELECT
|
|
DATE_FORMAT(CURDATE() + INTERVAL a.a HOUR, '%Y-%m-%d %H') AS time,
|
|
COALESCE(COUNT(dw.warning_time), 0) AS number
|
|
FROM (
|
|
SELECT 0 AS a
|
|
UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3
|
|
UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6
|
|
UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9
|
|
UNION ALL SELECT 10 UNION ALL SELECT 11 UNION ALL SELECT 12
|
|
UNION ALL SELECT 13 UNION ALL SELECT 14 UNION ALL SELECT 15
|
|
UNION ALL SELECT 16 UNION ALL SELECT 17 UNION ALL SELECT 18
|
|
UNION ALL SELECT 19 UNION ALL SELECT 20 UNION ALL SELECT 21
|
|
UNION ALL SELECT 22 UNION ALL SELECT 23
|
|
) AS a
|
|
LEFT JOIN dc_warning dw ON DATE_FORMAT(dw.warning_time, '%Y-%m-%d %H')
|
|
= DATE_FORMAT(CURDATE() + INTERVAL a.a HOUR, '%Y-%m-%d %H') and dw.warning_source!=6
|
|
GROUP BY time
|
|
ORDER BY time;
|
|
</select>
|
|
<select id="selectDailyCumulativeMonth" resultType="java.util.HashMap">
|
|
SELECT HOUR(warning_time) AS time, COUNT(*) AS number
|
|
FROM dc_warning
|
|
WHERE MONTH(warning_time) = MONTH(CURDATE())
|
|
AND YEAR(warning_time) = YEAR(CURDATE()) and warning_source!=6
|
|
GROUP BY HOUR(warning_time)
|
|
ORDER BY HOUR(warning_time);
|
|
</select>
|
|
<select id="selectWarningSourceGroup" resultType="java.util.HashMap">
|
|
SELECT warning_source warningSource,COUNT(*) AS number FROM dc_warning
|
|
where DATE_FORMAT(warning_time,'%Y-%m-%d')=DATE_FORMAT(#{warningTime},'%Y-%m-%d') and warning_source!=6
|
|
GROUP BY warning_source
|
|
</select>
|
|
<select id="selectWarningSourceGroupCount" resultType="java.lang.String">
|
|
SELECT COUNT(*) AS number FROM dc_warning
|
|
where DATE_FORMAT(warning_time,'%Y-%m-%d')=DATE_FORMAT(#{warningTime},'%Y-%m-%d') and warning_source!=6
|
|
</select>
|
|
<select id="selectWarningStateDay" resultType="java.util.HashMap">
|
|
select t1.warningState,t1.warningStateName,IFNULL(t2.num,0)number from
|
|
(select '1' as warningState,'上报' as warningStateName
|
|
UNION ALL select '2' as warningState,'已完成' as warningStateName
|
|
UNION ALL select '3' as warningState,'已终止' as warningStateName
|
|
UNION ALL select '4' as warningState,'自动结束' as warningStateName) t1
|
|
LEFT JOIN
|
|
(SELECT warning_state warningState,count(*) num
|
|
from dc_warning
|
|
where warning_source!=6 and DATE_FORMAT(warning_time,'%Y-%m-%d')=DATE_FORMAT(now(),'%Y-%m-%d')
|
|
GROUP BY warning_state)t2
|
|
on t1.warningState=t2.warningState
|
|
</select>
|
|
<select id="selectWarningTypeDay" resultType="java.util.HashMap">
|
|
SELECT warning_type warningType,COUNT(*) AS number FROM dc_warning
|
|
where warning_source!=6
|
|
GROUP BY warning_type
|
|
ORDER BY number DESC
|
|
</select>
|
|
<select id="selectWarningTrendDay" resultType="java.util.HashMap">
|
|
select t1.n as time,IFNULL(t2.num,0)as number from
|
|
(SELECT 0 AS n UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL
|
|
SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL
|
|
SELECT 8 UNION ALL SELECT 9 UNION ALL SELECT 10 UNION ALL SELECT 11 UNION ALL
|
|
SELECT 12 UNION ALL SELECT 13 UNION ALL SELECT 14 UNION ALL SELECT 15 UNION ALL
|
|
SELECT 16 UNION ALL SELECT 17 UNION ALL SELECT 18 UNION ALL SELECT 19 UNION ALL
|
|
SELECT 20 UNION ALL SELECT 21 UNION ALL SELECT 22 UNION ALL SELECT 23
|
|
) t1
|
|
left join
|
|
(select HOUR(warning_time) hours,count(*) num from dc_warning t1
|
|
left join dc_stake_mark t2 on t1.stake_mark = t2.stake_mark and t1.warning_source!=6
|
|
and t1.direction = t2.direction where date_format(warning_time,'%Y-%m-%d') = date_format(#{warningTime},'%Y-%m-%d')
|
|
and t2.section_id = #{sectionId}
|
|
and t1.direction=#{direction} and t2.direction=#{direction}
|
|
GROUP BY hours) t2
|
|
on t1.n = t2.hours
|
|
</select>
|
|
<select id="selectWarningTrendMonth" resultType="java.util.HashMap">
|
|
SELECT DATE(warning.warning_time) AS day, COUNT(*) AS number
|
|
FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark AS mark ON warning.stake_mark=mark.stake_mark
|
|
WHERE DATE_FORMAT(warning.warning_time,'%Y-%m') =DATE_FORMAT(#{warningTime},'%Y-%m')
|
|
AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and mark.`section_id`=#{sectionId} and warning.warning_source!=6
|
|
GROUP BY day
|
|
ORDER BY day
|
|
</select>
|
|
<select id="selectWarningTrendQuarter" resultType="java.util.HashMap">
|
|
SELECT
|
|
MONTH(warning.warning_time) AS month,
|
|
COUNT(*) AS number
|
|
FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark AS mark ON warning.stake_mark=mark.stake_mark
|
|
WHERE QUARTER(warning.warning_time)=#{quarter}
|
|
AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and mark.`section_id`=#{sectionId} and warning.warning_source!=6
|
|
GROUP BY MONTH
|
|
ORDER BY MONTH;
|
|
|
|
</select>
|
|
<select id="selectWarningTrendYear" resultType="java.util.HashMap">
|
|
select t1.n as month,IFNULL(t2.num,0)as number from
|
|
(SELECT 0 AS n UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL
|
|
SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL
|
|
SELECT 8 UNION ALL SELECT 9 UNION ALL SELECT 10 UNION ALL SELECT 11 UNION ALL
|
|
SELECT 12
|
|
) t1 left join
|
|
(select month(warning_time) hours,count(*) num from dc_warning t1
|
|
left join dc_stake_mark t2 on t1.stake_mark = t2.stake_mark and t1.direction = t2.direction where
|
|
DATE_FORMAT(t1.warning_time,'%Y')=DATE_FORMAT(#{warningTime},'%Y') and t2.section_id =#{sectionId}
|
|
and t1.direction=#{direction} and t1.warning_source!=6 and t2.direction=#{direction} GROUP BY hours) t2
|
|
on t1.n = t2.hours
|
|
</select>
|
|
<select id="selectWarningSectionTypeDayCount" resultType="java.lang.String">
|
|
SELECT COUNT(*) AS number FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark as mark on warning.stake_mark=mark.stake_mark
|
|
where DATE_FORMAT(warning.warning_time,'%Y-%m-%d')=DATE_FORMAT(#{warningTime},'%Y-%m-%d')
|
|
AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and mark.`section_id`=#{sectionId} and warning.warning_source!=6
|
|
</select>
|
|
<select id="selectWarningSectionTypeDay" resultType="java.util.HashMap">
|
|
SELECT warning.warning_type warningType,
|
|
COUNT(*) AS number
|
|
FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark as mark on warning.stake_mark=mark.stake_mark
|
|
where DATE_FORMAT(warning.warning_time,'%Y-%m-%d')=DATE_FORMAT(#{warningTime},'%Y-%m-%d')
|
|
AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and mark.`section_id`=#{sectionId} and warning.warning_source!=6
|
|
GROUP BY warning_type
|
|
ORDER BY number DESC
|
|
</select>
|
|
<select id="selectWarningSectionTypeMonthCount" resultType="java.lang.String">
|
|
SELECT COUNT(*) AS number FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark as mark on warning.stake_mark=mark.stake_mark
|
|
where DATE_FORMAT(warning.warning_time,'%Y-%m') =DATE_FORMAT(#{warningTime},'%Y-%m')
|
|
AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and mark.`section_id`=#{sectionId} and warning.warning_source!=6
|
|
</select>
|
|
<select id="selectWarningSectionTypeMonth" resultType="java.util.HashMap">
|
|
SELECT warning.warning_type warningType,COUNT(*) AS number
|
|
FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark as mark on warning.stake_mark=mark.stake_mark
|
|
where DATE_FORMAT(warning.warning_time,'%Y-%m') =DATE_FORMAT(#{warningTime},'%Y-%m')
|
|
AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and mark.`section_id`=#{sectionId} and warning.warning_source!=6
|
|
GROUP BY warning_type
|
|
ORDER BY number DESC
|
|
</select>
|
|
<select id="selectWarningSectionTypeQuarterCount" resultType="string">
|
|
SELECT
|
|
COUNT(*) AS number
|
|
FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark AS mark ON warning.stake_mark=mark.stake_mark
|
|
WHERE QUARTER(warning.warning_time)=#{quarter}
|
|
AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and mark.`section_id`=#{sectionId} and warning.warning_source!=6
|
|
</select>
|
|
<select id="selectWarningSectionTypeQuarter" resultType="java.util.HashMap">
|
|
SELECT
|
|
warning.warning_type warningType,
|
|
COUNT(*) AS number
|
|
FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark AS mark ON warning.stake_mark=mark.stake_mark
|
|
WHERE QUARTER(warning.warning_time)=#{quarter}
|
|
AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and mark.`section_id`=#{sectionId} and warning.warning_source!=6
|
|
GROUP BY warningType
|
|
|
|
</select>
|
|
<select id="selectWarningSectionTypeYearCount" resultType="java.lang.String">
|
|
SELECT COUNT(*) AS number FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark AS mark ON warning.stake_mark=mark.stake_mark
|
|
where mark.`section_id`=#{sectionId} AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and DATE_FORMAT(warning.warning_time,'%Y')=DATE_FORMAT(#{warningTime},'%Y')
|
|
and warning.warning_source!=6
|
|
</select>
|
|
<select id="selectWarningSectionTypeYear" resultType="java.util.HashMap">
|
|
SELECT warning.warning_type warningType, COUNT(*) AS number
|
|
FROM dc_warning as warning
|
|
LEFT JOIN dc_stake_mark AS mark ON warning.stake_mark=mark.stake_mark
|
|
where mark.`section_id`=#{sectionId} AND warning.direction=#{direction} and mark.direction=#{direction}
|
|
and DATE_FORMAT(warning.warning_time,'%Y')=DATE_FORMAT(#{warningTime},'%Y')
|
|
and warning.warning_source!=6
|
|
GROUP BY warningType
|
|
</select>
|
|
|
|
<select id="selectSectionMark" resultType="java.util.HashMap">
|
|
SELECT stake_mark stakeMark FROM dc_stake_mark AS mark WHERE mark.section_id=#{sectionId}
|
|
</select>
|
|
<select id="selectSectionNumber" resultType="java.lang.String">
|
|
select count(1) from dc_warning where stake_mark=#{stakeMark} AND warning.direction=#{direction}
|
|
</select>
|
|
<select id="selectWarningEscalation" resultType="java.util.HashMap">
|
|
select org.organization_name,warning.warning_type,warning.warning_subclass,
|
|
warning_title,warning.warning_state,DATE_FORMAT(warning.warning_time,'%Y-%m-%d %H:%m:%s') warningTime,
|
|
warning. warning_source,DATE_FORMAT(warning.create_time,'%Y-%m-%d %H:%m:%s') createTime from dc_warning as warning
|
|
LEFT JOIN dc_stake_mark as mark on warning.stake_mark=mark.stake_mark and mark.direction=warning.direction
|
|
LEFT JOIN dc_organization as org on mark.stake_mark=org.stake_mark
|
|
<where>
|
|
<if test="warningState != null and warningState != ''"> and warning.warning_state = #{warningState}</if>
|
|
</where>
|
|
</select>
|
|
|
|
<update id="updateWarning">
|
|
update dc_warning
|
|
<trim prefix="SET" suffixOverrides=",">
|
|
<if test="stakeMark != null and stakeMark != ''">stake_mark = #{stakeMark},</if>
|
|
<if test="direction != null">direction = #{direction},</if>
|
|
<if test="deptId != null">dept_id = #{deptId},</if>
|
|
<if test="warningState != null">warning_state = #{warningState},</if>
|
|
<if test="warningTime != null">warning_time = #{warningTime},</if>
|
|
<if test="userId != null">user_id = #{userId},</if>
|
|
<if test="warningSource != null">warning_source = #{warningSource},</if>
|
|
<if test="warningLevel != null">warning_level = #{warningLevel},</if>
|
|
<if test="remark != null">remark = #{remark},</if>
|
|
<if test="updateTime != null">update_time = #{updateTime},</if>
|
|
<if test="warningType != null">warning_type = #{warningType},</if>
|
|
<if test="warningSubclass != null">warning_subclass = #{warningSubclass},</if>
|
|
<if test="warningTitle != null">warning_title = #{warningTitle},</if>
|
|
<if test="otherConfig != null">other_config = #{otherConfig},</if>
|
|
<if test="lane != null">lane = #{lane},</if>
|
|
<if test="vehicleType != null">vehicle_type = #{vehicleType},</if>
|
|
</trim>
|
|
where id = #{id}
|
|
</update>
|
|
<select id="selectWarningMarkDay" resultType="java.lang.String">
|
|
select count(1) from dc_warning where stake_mark=#{stakeMark}
|
|
AND direction=#{direction} and DATE(warning_time)=DATE_FORMAT(#{warningTime},'%Y-%m-%d')
|
|
</select>
|
|
<select id="selectWarningMarkMonth" resultType="java.lang.String">
|
|
select count(1) from dc_warning where stake_mark=#{stakeMark}
|
|
AND direction=#{direction} and DATE_FORMAT(warning_time,'%Y-%m') =DATE_FORMAT(#{warningTime},'%Y-%m')
|
|
</select>
|
|
<select id="selectWarningMarkYear" resultType="java.lang.String">
|
|
select count(1) from dc_warning where stake_mark=#{stakeMark}
|
|
AND direction=#{direction} and YEAR(warning_time) =DATE_FORMAT(#{warningTime},'%Y')
|
|
</select>
|
|
<select id="selectWarningMarkQuarter" resultType="hashmap">
|
|
select count(1) number,stake_mark stakeMark,
|
|
CASE
|
|
WHEN MONTH(warning_time) BETWEEN 1 AND 3 THEN '第一季度'
|
|
WHEN MONTH(warning_time) BETWEEN 4 AND 6 THEN '第二季度'
|
|
WHEN MONTH(warning_time) BETWEEN 7 AND 9 THEN '第三季度'
|
|
ELSE '第四季度'
|
|
END AS QUARTER
|
|
from dc_warning where stake_mark=#{stakeMark} and
|
|
YEAR(warning_time) =DATE_FORMAT(#{warningTime},'%Y')
|
|
AND direction=#{direction} and stake_mark is not null
|
|
GROUP BY QUARTER
|
|
ORDER BY QUARTER;
|
|
</select>
|
|
<select id="selectNumber" resultType="int">
|
|
select count(1) from dc_warning
|
|
</select>
|
|
|
|
<select id="selectWarningMarkQuarterOptimize" resultType="java.util.HashMap">
|
|
SELECT DISTINCT m.stake_mark AS stakeMarkId,COALESCE(wc.count, 0) AS sectionNumber
|
|
FROM dc_stake_mark AS m LEFT JOIN ( SELECT stake_mark, COUNT(0) AS count FROM dc_warning WHERE
|
|
QUARTER(warning_time) =#{quarter} AND direction = #{direction} and warning_source!=6 GROUP BY stake_mark ) AS wc
|
|
ON m.stake_mark = wc.stake_mark WHERE m.section_id = #{sectionId}
|
|
</select>
|
|
<select id="selectWarningMarkDayOptimize" resultType="java.util.HashMap">
|
|
SELECT DISTINCT m.stake_mark AS stakeMarkId,COALESCE(wc.count, 0) AS sectionNumber FROM
|
|
dc_stake_mark AS m
|
|
LEFT JOIN ( SELECT stake_mark, COUNT(0) AS count FROM dc_warning WHERE
|
|
<if test = 'type == "day"' > DATE(warning_time)= DATE_FORMAT(#{warningTime},'%Y-%m-%d')</if>
|
|
<if test = 'type == "month"' > DATE_FORMAT(warning_time,'%Y-%m') =DATE_FORMAT(#{warningTime},'%Y-%m')</if>
|
|
<if test = 'type == "year"' > YEAR(warning_time) =DATE_FORMAT(#{warningTime},'%Y')</if>
|
|
AND direction = #{direction} and warning_source!=6 GROUP BY stake_mark ) AS wc ON m.stake_mark = wc.stake_mark
|
|
WHERE m.section_id = #{sectionId}
|
|
</select>
|
|
<select id="selectTypeNonAutomaticWarningDay" resultType="java.util.HashMap">
|
|
SELECT s.subclass,COALESCE(t.count, 0) AS number
|
|
FROM (
|
|
SELECT '1-1' AS warning_subclass , '拥堵' AS subclass UNION ALL
|
|
SELECT '2-1' AS warning_subclass, '行人' AS subclass UNION ALL
|
|
SELECT '6-4' AS warning_subclass, '抛洒物' AS subclass UNION ALL
|
|
SELECT '5-6' AS warning_subclass, '变道' AS subclass UNION ALL
|
|
SELECT '99-1' AS warning_subclass, '机占非' AS subclass UNION ALL
|
|
SELECT '6-3' AS warning_subclass, '路障' AS subclass UNION ALL
|
|
SELECT '7-1' AS warning_subclass, '施工' AS subclass UNION ALL
|
|
SELECT '4-10' AS warning_subclass, '停车' AS subclass UNION ALL
|
|
SELECT '5-2' AS warning_subclass, '压线' AS subclass UNION ALL
|
|
SELECT '5-3' AS warning_subclass, '掉头' AS subclass UNION ALL
|
|
SELECT '5-1' AS warning_subclass, '逆行' AS subclass
|
|
) s
|
|
LEFT JOIN ( SELECT warning_subclass, COUNT(1) AS count FROM dc_warning
|
|
where DATE_FORMAT(warning_time,'%Y-%m-%d')=DATE_FORMAT(#{warningTime},'%Y-%m-%d')
|
|
and warning_source=6
|
|
GROUP BY warning_subclass) t ON s.warning_subclass = t.warning_subclass
|
|
</select>
|
|
<select id="selectTypeNonAutomaticWarningMonth" resultType="java.util.HashMap">
|
|
SELECT s.subclass,COALESCE(t.count, 0) AS number
|
|
FROM (
|
|
SELECT '1-1' AS warning_subclass , '拥堵' AS subclass UNION ALL
|
|
SELECT '2-1' AS warning_subclass, '行人' AS subclass UNION ALL
|
|
SELECT '6-4' AS warning_subclass, '抛洒物' AS subclass UNION ALL
|
|
SELECT '5-6' AS warning_subclass, '变道' AS subclass UNION ALL
|
|
SELECT '99-1' AS warning_subclass, '机占非' AS subclass UNION ALL
|
|
SELECT '6-3' AS warning_subclass, '路障' AS subclass UNION ALL
|
|
SELECT '7-1' AS warning_subclass, '施工' AS subclass UNION ALL
|
|
SELECT '4-10' AS warning_subclass, '停车' AS subclass UNION ALL
|
|
SELECT '5-2' AS warning_subclass, '压线' AS subclass UNION ALL
|
|
SELECT '5-3' AS warning_subclass, '掉头' AS subclass UNION ALL
|
|
SELECT '5-1' AS warning_subclass, '逆行' AS subclass
|
|
) s
|
|
LEFT JOIN ( SELECT warning_subclass, COUNT(1) AS count FROM dc_warning
|
|
where DATE_FORMAT(warning_time,'%Y-%m')=DATE_FORMAT(#{warningTime},'%Y-%m')
|
|
and warning_source=6
|
|
GROUP BY warning_subclass) t ON s.warning_subclass = t.warning_subclass
|
|
</select>
|
|
<select id="selectTypeNonAutomaticWarningYear" resultType="java.util.HashMap">
|
|
SELECT s.subclass,COALESCE(t.count, 0) AS number
|
|
FROM (
|
|
SELECT '1-1' AS warning_subclass , '拥堵' AS subclass UNION ALL
|
|
SELECT '2-1' AS warning_subclass, '行人' AS subclass UNION ALL
|
|
SELECT '6-4' AS warning_subclass, '抛洒物' AS subclass UNION ALL
|
|
SELECT '5-6' AS warning_subclass, '变道' AS subclass UNION ALL
|
|
SELECT '99-1' AS warning_subclass, '其它' AS subclass UNION ALL
|
|
SELECT '6-3' AS warning_subclass, '路障' AS subclass UNION ALL
|
|
SELECT '7-1' AS warning_subclass, '施工' AS subclass UNION ALL
|
|
SELECT '4-10' AS warning_subclass, '停车' AS subclass UNION ALL
|
|
SELECT '5-2' AS warning_subclass, '压线' AS subclass UNION ALL
|
|
SELECT '5-3' AS warning_subclass, '掉头' AS subclass UNION ALL
|
|
SELECT '5-1' AS warning_subclass, '逆行' AS subclass
|
|
) s
|
|
LEFT JOIN ( SELECT warning_subclass, COUNT(1) AS count FROM dc_warning
|
|
where DATE_FORMAT(warning_time,'%Y')=DATE_FORMAT(#{warningTime},'%Y')
|
|
and warning_source=6
|
|
GROUP BY warning_subclass) t ON s.warning_subclass = t.warning_subclass
|
|
</select>
|
|
<select id="selectNonAutomaticWarningDay" resultType="java.util.HashMap">
|
|
select t1.n as time,IFNULL(t2.num,0)as number from
|
|
(SELECT 0 AS n UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL
|
|
SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL
|
|
SELECT 8 UNION ALL SELECT 9 UNION ALL SELECT 10 UNION ALL SELECT 11 UNION ALL
|
|
SELECT 12 UNION ALL SELECT 13 UNION ALL SELECT 14 UNION ALL SELECT 15 UNION ALL
|
|
SELECT 16 UNION ALL SELECT 17 UNION ALL SELECT 18 UNION ALL SELECT 19 UNION ALL
|
|
SELECT 20 UNION ALL SELECT 21 UNION ALL SELECT 22 UNION ALL SELECT 23
|
|
) t1
|
|
left join
|
|
(select HOUR(warning_time) hours,count(*) num from dc_warning
|
|
where date_format(warning_time,'%Y-%m-%d') = date_format(#{warningTime},'%Y-%m-%d')
|
|
and warning_source=6
|
|
GROUP BY hours) t2
|
|
on t1.n = t2.hours
|
|
</select>
|
|
<select id="selectNonAutomaticWarningMonth" resultType="java.util.HashMap">
|
|
SELECT DATE(warning.warning_time) AS day, COUNT(*) AS number
|
|
FROM dc_warning as warning
|
|
WHERE DATE_FORMAT(warning.warning_time,'%Y-%m') =DATE_FORMAT(#{warningTime},'%Y-%m')
|
|
and warning_source=6
|
|
GROUP BY day
|
|
ORDER BY day
|
|
</select>
|
|
<select id="selectNonAutomaticWarningYear" resultType="java.util.HashMap">
|
|
select t1.n as month,IFNULL(t2.num,0)as number from
|
|
(SELECT 0 AS n UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL
|
|
SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL
|
|
SELECT 8 UNION ALL SELECT 9 UNION ALL SELECT 10 UNION ALL SELECT 11 UNION ALL
|
|
SELECT 12
|
|
) t1 left join
|
|
(select month(warning_time) hours,count(*) num from dc_warning t1
|
|
where DATE_FORMAT(t1.warning_time,'%Y')=DATE_FORMAT(#{warningTime},'%Y') and warning_source=6
|
|
GROUP BY hours) t2
|
|
on t1.n = t2.hours
|
|
</select>
|
|
<select id="selectNonAutomaticWarningFacilityDay" resultType="java.util.HashMap">
|
|
select facility_name as facilityName, COALESCE(w_count.number, 0) AS number
|
|
from dc_facility AS s
|
|
LEFT JOIN (SELECT w.stake_mark, COUNT(1) AS number FROM dc_warning AS w
|
|
WHERE DATE_FORMAT(w.warning_time,'%Y-%m-%d') = DATE_FORMAT(#{warningTime},'%Y-%m-%d')
|
|
and w.warning_source=6
|
|
GROUP BY w.stake_mark ) AS w_count ON s.stake_mark = w_count.stake_mark
|
|
</select>
|
|
<select id="selectNonAutomaticWarningFacilityMonth" resultType="java.util.HashMap">
|
|
select facility_name as facilityName, COALESCE(w_count.number, 0) AS number
|
|
from dc_facility AS s
|
|
LEFT JOIN (SELECT w.stake_mark, COUNT(1) AS number FROM dc_warning AS w
|
|
WHERE DATE_FORMAT(w.warning_time,'%Y-%m') = DATE_FORMAT(#{warningTime},'%Y-%m')
|
|
and w.warning_source=6
|
|
GROUP BY w.stake_mark ) AS w_count ON s.stake_mark = w_count.stake_mark
|
|
</select>
|
|
<select id="selectNonAutomaticWarningFacilityYear" resultType="java.util.HashMap">
|
|
select facility_name as facilityName, COALESCE(w_count.number, 0) AS number
|
|
from dc_facility AS s
|
|
LEFT JOIN (SELECT w.stake_mark, COUNT(1) AS number FROM dc_warning AS w
|
|
WHERE DATE_FORMAT(w.warning_time,'%Y') = DATE_FORMAT(#{warningTime},'%Y')
|
|
and w.warning_source=6
|
|
GROUP BY w.stake_mark ) AS w_count ON s.stake_mark = w_count.stake_mark
|
|
</select>
|
|
|
|
|
|
<!-- <select id="selectWarningMarkDayOptimize" resultType="java.util.HashMap">-->
|
|
<!-- SELECT DISTINCT m.stake_mark stakeMarkId,-->
|
|
<!-- (SELECT count( 0 ) FROM dc_warning w WHERE w.stake_mark = m.stake_mark-->
|
|
<!-- <if test = 'type == "day"' >and DATE(w.warning_time)= DATE_FORMAT(#{warningTime},'%Y-%m-%d')</if>-->
|
|
<!-- <if test = 'type == "month"' >and DATE_FORMAT(w.warning_time,'%Y-%m') =DATE_FORMAT(#{warningTime},'%Y-%m')</if>-->
|
|
<!-- <if test = 'type == "year"' >and YEAR(w.warning_time) =DATE_FORMAT(#{warningTime},'%Y')</if>-->
|
|
<!-- AND w.direction = #{direction}) sectionNumber FROM dc_stake_mark AS m-->
|
|
<!-- WHERE m.section_id = #{sectionId}-->
|
|
<!-- HAVING sectionNumber!=0-->
|
|
<!-- </select>-->
|
|
|
|
|
|
</mapper>
|