integrated_traffic/src/main/resources/mybatis/datasource/hiddenDangerCheckStandard/CustomCheckUserMapper.xml

249 lines
5.7 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="com.zcloud.mapper.datasource.hiddenDangerCheckStandard.CustomCheckUserMapper">
<!--表名 -->
<sql id="tableName">
BUS_HIDDENDANGERCHECKSTANDARD_CHECKUSER
</sql>
<!--数据字典表名 -->
<sql id="dicTableName">
SYS_DICTIONARIES
</sql>
<!-- 字段 -->
<sql id="Field">
f.CHECKRECORD_ID,
f.DEPARTMENT_ID,
f.USER_ID,
f.CHECKUSER_ID,
f.DEPARTMENT_NAME,
f.USER_NAME
</sql>
<!-- 字段用于新增 -->
<sql id="Field2">
CHECKRECORD_ID,
DEPARTMENT_ID,
USER_ID,
CHECKUSER_ID,
DEPARTMENT_NAME,
USER_NAME
</sql>
<!-- 字段值 -->
<sql id="FieldValue">
#{CHECKRECORD_ID},
#{DEPARTMENT_ID},
#{USER_ID},
#{CHECKUSER_ID},
#{DEPARTMENT_NAME},
#{USER_NAME}
</sql>
<!-- 新增-->
<insert id="save" parameterType="pd">
insert into
<include refid="tableName"></include>
(
<include refid="Field2"></include>
) values (
<include refid="FieldValue"></include>
)
</insert>
<!-- 删除-->
<delete id="delete" parameterType="pd">
delete from
<include refid="tableName"></include>
where
CHECKRECORD_ID = #{CHECKRECORD_ID}
</delete>
<!-- 修改 -->
<update id="edit" parameterType="pd">
update
<include refid="tableName"></include>
set
CHECKRECORD_ID = #{CHECKRECORD_ID},
DEPARTMENT_ID = #{DEPARTMENT_ID},
USER_ID = #{USER_ID},
CHECKUSER_ID = CHECKUSER_ID
where
CHECKUSER_ID = #{CHECKUSER_ID}
</update>
<!-- 通过ID获取数据 -->
<select id="findById" parameterType="pd" resultType="pd">
select
<include refid="Field"></include>
from
<include refid="tableName"></include> f
where
f.CHECKUSER_ID = #{CHECKUSER_ID}
</select>
<!-- 列表 -->
<select id="datalistPage" parameterType="page" resultType="pd">
select
<include refid="Field"></include>
from
<include refid="tableName"></include> f
where f.ISDELETE = '0'
<if test="pd.KEYWORDS != null and pd.KEYWORDS != ''"><!-- 关键词检索 -->
and
(
<!-- 根据需求自己加检索条件
字段1 LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%')
or
字段2 LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%')
-->
)
</if>
</select>
<!-- 列表(全部) -->
<select id="listAll" parameterType="pd" resultType="pd">
select
<include refid="Field"></include>
from
<include refid="tableName"></include> f
</select>
<!-- 批量删除 -->
<delete id="deleteAll" parameterType="String">
update
<include refid="tableName"></include>
set
ISDELETE = '1'
where
CHECKUSER_ID in
<foreach item="item" index="index" collection="ArrayDATA_IDS" open="(" separator="," close=")">
#{item}
</foreach>
</delete>
<!-- 查询人员检查数 -->
<select id="countCheByUser" parameterType="pd" resultType="pd">
SELECT
c.USER_ID,
count( c.CHECKUSER_ID ) NUM
FROM
bus_checkuser c
LEFT JOIN bus_checkrecord cr ON c.CHECKRECORD_ID = cr.CHECKRECORD_ID
WHERE
cr.isdelete = '0'
AND cr.FINISHED = '1'
AND cr.ISSTATISTICS = '1'
AND c.user_id IS NOT NULL
AND c.user_id != ''
AND cr.CORPINFO_ID = #{CORPINFO_ID}
and
cr.CHECK_TIME BETWEEN CONCAT(#{STARTTIME},' 00:00:00') and CONCAT(#{ENDTIME},' 23:59:59')
GROUP BY
c.user_id
</select>
<!-- 查看检查清单检查人 -->
<select id="getCheckUser" parameterType="pd" resultType="pd">
SELECT
GROUP_CONCAT(DISTINCT IFNULL(f.USER_NAME, u.NAME)) USERS
FROM
<include refid="tableName"></include> f
LEFT JOIN SYS_USER u ON u.USER_ID = f.USER_ID
WHERE u.NAME IS NOT NULL
AND u.NAME != ''
AND f.CHECKRECORD_ID = #{CHECKRECORD_ID}
GROUP BY
f.CHECKRECORD_ID
</select>
<!-- 绩效得分 -->
<select id="getDeptExamine" parameterType="pd" resultType="pd" >
SELECT
d.DEPARTMENT_ID,
ifnull(sta.NUM,0) as sta_count,
ifnull(che.NUM,0) as check_count
FROM
OA_DEPARTMENT d
left JOIN (
SELECT
sum(f.NOTEXAMINEDNUM) NUM,
u.DEPARTMENT_ID
FROM
bus_list_statistics f
LEFT JOIN SYS_USER u ON u.USER_ID = f.USER_ID
WHERE
(
f.STARTTIME BETWEEN #{STARTTIME} and #{ENDTIME}
or
f.ENDTIME BETWEEN #{STARTTIME} and #{ENDTIME}
or
(f.STARTTIME &lt;= #{STARTTIME} and f.ENDTIME &gt;= #{ENDTIME})
)
group by u.DEPARTMENT_ID
) sta on sta.DEPARTMENT_ID=d.DEPARTMENT_ID
LEFT JOIN (
SELECT
count( distinct cr.LISTMANAGER_ID ) NUM,
c.DEPARTMENT_ID
FROM
bus_checkuser c
LEFT JOIN bus_checkrecord cr ON c.CHECKRECORD_ID = cr.CHECKRECORD_ID
WHERE
cr.isdelete = '0'
AND cr.FINISHED = '1'
AND cr.ISSTATISTICS = '1'
AND cr.CHECK_TIME BETWEEN #{STARTTIME} and #{ENDTIME}
group by c.DEPARTMENT_ID
) che on che.DEPARTMENT_ID = d.DEPARTMENT_ID
where
d.ISDELETE = 0
</select>
<select id="getUserExamine" parameterType="pd" resultType="pd" >
SELECT
u.USER_ID,
ifnull(sta.NUM,0) as sta_count,
ifnull(che.NUM,0) as check_count
FROM
SYS_USER u
left JOIN (
SELECT
sum(f.NOTEXAMINEDNUM) NUM,
f.USER_ID
FROM
bus_list_statistics f
WHERE
(
f.STARTTIME BETWEEN #{STARTTIME} and #{ENDTIME}
or
f.ENDTIME BETWEEN #{STARTTIME} and #{ENDTIME}
or
(f.STARTTIME &lt;= #{STARTTIME} and f.ENDTIME &gt;= #{ENDTIME})
)
group by f.USER_ID
) sta on sta.USER_ID=u.USER_ID
LEFT JOIN (
SELECT
count( distinct cr.LISTMANAGER_ID ) NUM,
c.USER_ID
FROM
bus_checkuser c
LEFT JOIN bus_checkrecord cr ON c.CHECKRECORD_ID = cr.CHECKRECORD_ID
WHERE
cr.isdelete = '0'
AND cr.FINISHED = '1'
AND cr.ISSTATISTICS = '1'
AND cr.CHECK_TIME BETWEEN #{STARTTIME} and #{ENDTIME}
group by c.USER_ID
) che on che.USER_ID = u.USER_ID
where
u.ISDELETE = 0
</select>
</mapper>