123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555 |
- <?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.huaxu.dao.AlarmDetailMapper">
- <sql id="Base_Column_List">
- a.ID as "id"
- ,a.TENANT_ID as "tenantId"
- ,a.DEVICE_ID as "deviceId"
- ,a.COMPANY_ORG_ID as "companyOrgId"
- ,a.DEPT_ORG_ID as "deptOrgId"
- ,a.ALARM_TYPE as "alarmType"
- ,a.ATTRIBUTE_ID as "attributeId"
- ,a.ALARM_VALUE as "alarmValue"
- ,a.ALARM_CONTENT as "alarmContent"
- ,a.ALARM_START_TIME as "alarmStartTime"
- ,a.ALARM_END_TIME as "alarmEndTime"
- ,a.STATE as "state"
- ,a.OP_STATE as "opState"
- ,a.REMARK as "remark"
- ,a.STATUS as "status"
- ,a.DATE_CREATE as "dateCreate"
- ,a.CREATE_BY as "createBy"
- ,a.DATE_UPDATE as "dateUpdate"
- ,a.UPDATE_BY as "updateBy"
- ,a.MIN_VALUE as "minValue"
- ,a.MAX_VALUE as "maxValue"
- ,timestampdiff(MINUTE,ifnull(a.ALARM_END_TIME,now()),a.ALARM_START_TIME) as "duration"
- /*,(case when ALARM_END_TIME is not null then timestampdiff(MINUTE,a.ALARM_END_TIME,a.ALARM_START_TIME) else null end ) as "duration"*/
- ,att.`NAME` as "attributeName"
- ,s.SCENE_NAME as "sceneName"
- ,d.DEVICE_NAME as "deviceName"
- ,t.DEVICE_TYPE as "deviceType"
- ,d.ADDRESS as "address"
- ,d.POINT_X as "pointX"
- ,d.POINT_Y as "pointY"
- ,ast.ALARM_CONDITION +" " +ast.ALARM_VALUE as "alermRule"
- ,concat(ifnull(ast.ALARM_CONDITION,''),ifnull(ast.ALARM_VALUE,'')) as "alermRule"
- ,att.UNIT as "unit"
- </sql>
- <sql id="Base_Column_List_real_time">
- a.ID as "id"
- ,a.STATE as "state"
- ,a.OP_STATE as "opState"
- ,s.SCENE_NAME as "sceneName"
- ,d.DEVICE_NAME as "deviceName"
- ,t.DEVICE_TYPE as "deviceType"
- ,a.ALARM_TYPE as "alarmType"
- ,att.`NAME` as "attributeName"
- ,a.ALARM_START_TIME as "alarmStartTime"
- ,d.ADDRESS as "address"
- ,d.POINT_X as "pointX"
- ,d.POINT_Y as "pointY"
- ,a.ALARM_VALUE as "alarmValue"
- ,a.ALARM_CONTENT as "alarmContent"
- </sql>
- <sql id="Base_Column_List_history">
- a.ID as "id"
- ,a.STATE as "state"
- ,a.OP_STATE as "opState"
- ,s.SCENE_NAME as "sceneName"
- ,d.DEVICE_NAME as "deviceName"
- ,t.DEVICE_TYPE as "deviceType"
- ,a.ALARM_TYPE as "alarmType"
- ,att.`NAME` as "attributeName"
- ,a.ALARM_START_TIME as "alarmStartTime"
- ,d.ADDRESS as "address"
- ,d.POINT_X as "pointX"
- ,d.POINT_Y as "pointY"
- ,a.MIN_VALUE as "minValue"
- ,a.MAX_VALUE as "maxValue"
- ,concat(ifnull(ast.ALARM_CONDITION,''),ifnull(ast.ALARM_VALUE,'')) as "alermRule"
- ,a.ALARM_END_TIME as "alarmEndTime"
- ,timestampdiff(MINUTE,ifnull(a.ALARM_END_TIME,now()),a.ALARM_START_TIME) as "duration"
- </sql>
- <sql id="alarmDetailJoins">
- left join sms_device d on a.DEVICE_ID =d.id and d.`STATUS` = 1
- left join sms_scene s on d.SCENE_ID =s.id and s.`STATUS` =1
- left join sms_device_type t on d.DEVICE_TYPE_ID =t.ID
- left join sms_alarm_setting ast on ast.id= a.ATTRIBUTE_ID
- left join sms_device_attribute att on att.id=ast.ATTRIBUTE_ID
- </sql>
- <select id="selectById" resultType="com.huaxu.dto.AlarmDetailsDto">
- select
- <include refid="Base_Column_List"/>
- from sms_alarm_details a
- <include refid="alarmDetailJoins"/>
- where a.`STATUS` = 1
- and a.id=#{id}
- </select>
- <!--通过实体作为筛选条件查询-->
- <select id="selectList" resultType="com.huaxu.dto.AlarmDetailsDto">
- select
- <include refid="Base_Column_List"/>
- from sms_alarm_details a
- <include refid="alarmDetailJoins"/>
- where a.`STATUS` = 1
- <if test="alarmDetailsDto.condition != null and alarmDetailsDto.condition != ''">
- and (s.SCENE_NAME like concat('%', #{alarmDetailsDto.condition},'%') or d.DEVICE_NAME like concat('%', #{alarmDetailsDto.condition},'%') )
- </if>
- <if test="alarmDetailsDto.tenantId != null and alarmDetailsDto.tenantId != ''">
- and a.TENANT_ID = #{alarmDetailsDto.tenantId}
- </if>
- <if test="alarmDetailsDto.alarmType != null and alarmDetailsDto.alarmType != ''">
- and a.ALARM_TYPE = #{alarmDetailsDto.alarmType}
- </if>
- <if test="alarmDetailsDto.opState != null">
- and a.OP_STATE =#{alarmDetailsDto.opState}
- </if>
- <if test="alarmDetailsDto.startTime != null">
- and a.ALARM_START_TIME >=#{alarmDetailsDto.startTime}
- </if>
- <if test="alarmDetailsDto.endTime != null">
- and a.ALARM_START_TIME <=DATE_ADD(#{alarmDetailsDto.endTime},INTERVAL 1 DAY)
- </if>
- <if test="alarmDetailsDto.userType!=null and alarmDetailsDto.userType!=-999 and alarmDetailsDto.userType!=-9999 and alarmDetailsDto.programItems != null and alarmDetailsDto.programItems.size() > 0">
- <if test="alarmDetailsDto.permissonType == 5 or alarmDetailsDto.permissonType == 2">
- and ( a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- or
- a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- )
- </if>
- <if test="alarmDetailsDto.permissonType == 4 or alarmDetailsDto.permissonType == 3">
- and a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- </if>
- <if test="alarmDetailsDto.permissonType == 1">
- and a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- and (a.DEPT_ORG_ID is null or a.DEPT_ORG_ID =0)
- </if>
- </if>
- </select>
- <!-- 新增所有列 -->
- <insert id="insert" keyProperty="id" useGeneratedKeys="true">
- INSERT INTO sms_alarm_details ( TENANT_ID , DEVICE_ID , COMPANY_ORG_ID , DEPT_ORG_ID , ALARM_TYPE , ATTRIBUTE_ID , ALARM_VALUE , ALARM_CONTENT , ALARM_START_TIME , ALARM_END_TIME , STATE , OP_STATE , REMARK , STATUS , DATE_CREATE , CREATE_BY , DATE_UPDATE , UPDATE_BY )
- VALUES ( #{tenantId} , #{deviceId} , #{companyOrgId} , #{deptOrgId} , #{alarmType} , #{attributeId} , #{alarmValue} , #{alarmContent} , #{alarmStartTime} , #{alarmEndTime} , #{state} , #{opState} , #{remark} , #{status} , #{dateCreate} , #{createBy} , #{dateUpdate} , #{updateBy} )
- </insert>
- <!-- 批量新增 -->
- <insert id="batchInsert">
- INSERT INTO sms_alarm_details ( TENANT_ID , DEVICE_ID , COMPANY_ORG_ID , DEPT_ORG_ID , ALARM_TYPE , ATTRIBUTE_ID , ALARM_VALUE , ALARM_CONTENT , ALARM_START_TIME , ALARM_END_TIME , STATE , OP_STATE , REMARK , STATUS , DATE_CREATE , CREATE_BY , DATE_UPDATE , UPDATE_BY )
- values
- <foreach collection="alarmDetails" item="item" index="index" separator=",">
- ( #{item.tenantId} , #{item.deviceId} , #{item.companyOrgId} , #{item.deptOrgId} , #{item.alarmType} , #{item.attributeId} , #{item.alarmValue} , #{item.alarmContent} , #{item.alarmStartTime} , #{item.alarmEndTime} , #{item.state} , #{item.opState} , #{item.remark} , #{item.status} , #{item.dateCreate} , #{item.createBy} , #{item.dateUpdate} , #{item.updateBy} )
- </foreach>
- </insert>
- <!-- 通过主键修改数据 -->
- <update id="update">
- UPDATE sms_alarm_details
- <set>
- <if test="tenantId != null and tenantId != '' ">
- TENANT_ID = #{tenantId},
- </if>
- <if test="deviceId != null ">
- DEVICE_ID = #{deviceId},
- </if>
- <if test="companyOrgId != null ">
- COMPANY_ORG_ID = #{companyOrgId},
- </if>
- <if test="deptOrgId != null ">
- DEPT_ORG_ID = #{deptOrgId},
- </if>
- <if test="alarmType != null ">
- ALARM_TYPE = #{alarmType},
- </if>
- <if test="attributeId != null ">
- ATTRIBUTE_ID = #{attributeId},
- </if>
- <if test="alarmValue != null ">
- ALARM_VALUE = #{alarmValue},
- </if>
- <if test="alarmContent != null and alarmContent != '' ">
- ALARM_CONTENT = #{alarmContent},
- </if>
- <if test="alarmStartTime != null ">
- ALARM_START_TIME = #{alarmStartTime},
- </if>
- <if test="alarmStartTime != null ">
- ALARM_START_TIME = #{alarmStartTime},
- </if>
- <if test="alarmEndTime != null ">
- ALARM_END_TIME = #{alarmEndTime},
- </if>
- <if test="state != null ">
- STATE = #{state},
- </if>
- <if test="opState != null ">
- OP_STATE = #{opState},
- </if>
- <if test="remark != null and remark != '' ">
- REMARK = #{remark},
- </if>
- <if test="status != null ">
- STATUS = #{status},
- </if>
- <if test="dateUpdate != null ">
- DATE_UPDATE = #{dateUpdate},
- </if>
- <if test="updateBy != null and updateBy != ''">
- UPDATE_BY = #{updateBy}
- </if>
- </set>
- WHERE ID = #{id};
- </update>
- <!--通过主键删除-->
- <delete id="deleteById">
- UPDATE sms_alarm_details set STATUS = 0 where id = #{id}
- </delete>
- <!--删除-->
- <delete id="batchDelete">
- UPDATE sms_alarm_details set STATUS = 0
- where id in
- <foreach collection="ids" item="item" open="(" close=")" separator=",">
- #{item}
- </foreach>
- </delete>
- <!-- 报警挂起、恢复 -->
- <delete id="suspendedById">
- UPDATE sms_alarm_details set op_state = #{opState} , DATE_UPDATE = #{dateUpdate}, UPDATE_BY = #{updateBy} where id = #{id}
- </delete>
- <!-- 分页查询 -->
- <select id="selectPage" resultType="com.huaxu.dto.AlarmDetailsDto">
- select
- <include refid="Base_Column_List"/>
- from sms_alarm_details a
- <include refid="alarmDetailJoins"/>
- where a.`STATUS` = 1
- <if test="alarmDetailsDto.condition != null and alarmDetailsDto.condition != ''">
- and (s.SCENE_NAME like concat('%', #{alarmDetailsDto.condition},'%') or d.DEVICE_NAME like concat('%', #{alarmDetailsDto.condition},'%') )
- </if>
- <if test="alarmDetailsDto.tenantId != null and alarmDetailsDto.tenantId != ''">
- and a.TENANT_ID = #{alarmDetailsDto.tenantId}
- </if>
- <if test="alarmDetailsDto.alarmType != null and alarmDetailsDto.alarmType != ''">
- and a.ALARM_TYPE = #{alarmDetailsDto.alarmType}
- </if>
- <if test="alarmDetailsDto.state != null">
- and a.STATE =#{alarmDetailsDto.state}
- </if>
- <if test="alarmDetailsDto.opState != null">
- and a.OP_STATE =#{alarmDetailsDto.opState}
- </if>
- <if test="alarmDetailsDto.startTime != null">
- and a.ALARM_START_TIME >=#{alarmDetailsDto.startTime}
- </if>
- <if test="alarmDetailsDto.endTime != null">
- and a.ALARM_START_TIME <=DATE_ADD(#{alarmDetailsDto.endTime},INTERVAL 1 DAY)
- </if>
- <if test="alarmDetailsDto.userType!=null and alarmDetailsDto.userType!=-999 and alarmDetailsDto.userType!=-9999 and alarmDetailsDto.programItems != null and alarmDetailsDto.programItems.size() > 0">
- <if test="alarmDetailsDto.permissonType == 5 or alarmDetailsDto.permissonType == 2">
- and ( a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- or
- a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- )
- </if>
- <if test="alarmDetailsDto.permissonType == 4 or alarmDetailsDto.permissonType == 3">
- and a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- </if>
- <if test="alarmDetailsDto.permissonType == 1">
- and a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- and (a.DEPT_ORG_ID is null or a.DEPT_ORG_ID =0)
- </if>
- </if>
- </select>
- <!-- 实时数据分页分页查询 -->
- <select id="selectRealTimePage" resultType="com.huaxu.dto.AlarmDetailsRealTimeDto">
- select
- <include refid="Base_Column_List_real_time"/>
- from sms_alarm_details a
- <include refid="alarmDetailJoins"/>
- where a.`STATUS` = 1 and a.state = 1
- <if test="alarmDetailsDto.condition != null and alarmDetailsDto.condition != ''">
- and (s.SCENE_NAME like concat('%', #{alarmDetailsDto.condition},'%') or d.DEVICE_NAME like concat('%', #{alarmDetailsDto.condition},'%') )
- </if>
- <if test="alarmDetailsDto.tenantId != null and alarmDetailsDto.tenantId != ''">
- and a.TENANT_ID = #{alarmDetailsDto.tenantId}
- </if>
- <if test="alarmDetailsDto.alarmType != null and alarmDetailsDto.alarmType != ''" >
- and a.ALARM_TYPE = #{alarmDetailsDto.alarmType}
- </if>
- <if test="alarmDetailsDto.opState != null">
- and a.OP_STATE =#{alarmDetailsDto.opState}
- </if>
- <if test="alarmDetailsDto.startTime != null">
- and a.ALARM_START_TIME >=#{alarmDetailsDto.startTime}
- </if>
- <if test="alarmDetailsDto.endTime != null">
- and a.ALARM_START_TIME <=DATE_ADD(#{alarmDetailsDto.endTime},INTERVAL 1 DAY)
- </if>
- <if test="alarmDetailsDto.userType!=null and alarmDetailsDto.userType!=-999 and alarmDetailsDto.userType!=-9999 and alarmDetailsDto.programItems != null and alarmDetailsDto.programItems.size() > 0">
- <if test="alarmDetailsDto.permissonType == 5 or alarmDetailsDto.permissonType == 2">
- and ( a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- or
- a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- )
- </if>
- <if test="alarmDetailsDto.permissonType == 4 or alarmDetailsDto.permissonType == 3">
- and a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- </if>
- <if test="alarmDetailsDto.permissonType == 1">
- and a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- and (a.DEPT_ORG_ID is null or a.DEPT_ORG_ID =0)
- </if>
- </if>
- </select>
- <!-- 历史数据分页分页查询 -->
- <select id="selectHistoryPage" resultType="com.huaxu.dto.AlarmDetailsHistoryDto">
- select
- <include refid="Base_Column_List_history"/>
- from sms_alarm_details a
- <include refid="alarmDetailJoins"/>
- where a.`STATUS` = 1 and a.state = 0
- <if test="alarmDetailsDto.condition != null and alarmDetailsDto.condition != ''">
- and (s.SCENE_NAME like concat('%', #{alarmDetailsDto.condition},'%') or d.DEVICE_NAME like concat('%', #{alarmDetailsDto.condition},'%') )
- </if>
- <if test="alarmDetailsDto.tenantId != null and alarmDetailsDto.tenantId != ''">
- and a.TENANT_ID = #{alarmDetailsDto.tenantId}
- </if>
- <if test="alarmDetailsDto.alarmType != null and alarmDetailsDto.alarmType != ''">
- and a.ALARM_TYPE = #{alarmDetailsDto.alarmType}
- </if>
- <if test="alarmDetailsDto.opState != null">
- and a.OP_STATE =#{alarmDetailsDto.opState}
- </if>
- <if test="alarmDetailsDto.startTime != null">
- and a.ALARM_START_TIME >=#{alarmDetailsDto.startTime}
- </if>
- <if test="alarmDetailsDto.endTime != null">
- and a.ALARM_START_TIME <=DATE_ADD(#{alarmDetailsDto.endTime},INTERVAL 1 DAY)
- </if>
- <if test="alarmDetailsDto.userType!=null and alarmDetailsDto.userType!=-999 and alarmDetailsDto.userType!=-9999 and alarmDetailsDto.programItems != null and alarmDetailsDto.programItems.size() > 0">
- <if test="alarmDetailsDto.permissonType == 5 or alarmDetailsDto.permissonType == 2">
- and ( a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- or
- a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- )
- </if>
- <if test="alarmDetailsDto.permissonType == 4 or alarmDetailsDto.permissonType == 3">
- and a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- </if>
- <if test="alarmDetailsDto.permissonType == 1">
- and a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- and (a.DEPT_ORG_ID is null or a.DEPT_ORG_ID =0)
- </if>
- </if>
- </select>
- <!--通过实体作为筛选条件查询-->
- <select id="selectRealTimeList" resultType="com.huaxu.dto.AlarmDetailsRealTimeDto">
- select
- <include refid="Base_Column_List_real_time"/>
- from sms_alarm_details a
- <include refid="alarmDetailJoins"/>
- where a.`STATUS` = 1 and a.state = 1
- <if test="alarmDetailsDto.condition != null and alarmDetailsDto.condition != ''">
- and (s.SCENE_NAME like concat('%', #{alarmDetailsDto.condition},'%') or d.DEVICE_NAME like concat('%', #{alarmDetailsDto.condition},'%') )
- </if>
- <if test="alarmDetailsDto.tenantId != null and alarmDetailsDto.tenantId != ''">
- and a.TENANT_ID = #{alarmDetailsDto.tenantId}
- </if>
- <if test="alarmDetailsDto.alarmType != null and alarmDetailsDto.alarmType != ''">
- and a.ALARM_TYPE = #{alarmDetailsDto.alarmType}
- </if>
- <if test="alarmDetailsDto.opState != null">
- and a.OP_STATE =#{alarmDetailsDto.opState}
- </if>
- <if test="alarmDetailsDto.startTime != null">
- and a.ALARM_START_TIME >=#{alarmDetailsDto.startTime}
- </if>
- <if test="alarmDetailsDto.endTime != null">
- and a.ALARM_START_TIME <=DATE_ADD(#{alarmDetailsDto.endTime},INTERVAL 1 DAY)
- </if>
- <if test="alarmDetailsDto.userType!=null and alarmDetailsDto.userType!=-999 and alarmDetailsDto.userType!=-9999 and alarmDetailsDto.programItems != null and alarmDetailsDto.programItems.size() > 0">
- <if test="alarmDetailsDto.permissonType == 5 or alarmDetailsDto.permissonType == 2">
- and ( a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- or
- a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- )
- </if>
- <if test="alarmDetailsDto.permissonType == 4 or alarmDetailsDto.permissonType == 3">
- and a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- </if>
- <if test="alarmDetailsDto.permissonType == 1">
- and a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- and (a.DEPT_ORG_ID is null or a.DEPT_ORG_ID =0)
- </if>
- </if>
- </select>
- <!--通过实体作为筛选条件查询-->
- <select id="selectHistoryList" resultType="com.huaxu.dto.AlarmDetailsHistoryDto">
- select
- <include refid="Base_Column_List_history"/>
- from sms_alarm_details a
- <include refid="alarmDetailJoins"/>
- where a.`STATUS` = 1 and a.state = 0
- <if test="alarmDetailsDto.condition != null and alarmDetailsDto.condition != ''">
- and (s.SCENE_NAME like concat('%', #{alarmDetailsDto.condition},'%') or d.DEVICE_NAME like concat('%', #{alarmDetailsDto.condition},'%') )
- </if>
- <if test="alarmDetailsDto.tenantId != null and alarmDetailsDto.tenantId != ''">
- and a.TENANT_ID = #{alarmDetailsDto.tenantId}
- </if>
- <if test="alarmDetailsDto.alarmType != null and alarmDetailsDto.alarmType != ''">
- and a.ALARM_TYPE = #{alarmDetailsDto.alarmType}
- </if>
- <if test="alarmDetailsDto.opState != null">
- and a.OP_STATE =#{alarmDetailsDto.opState}
- </if>
- <if test="alarmDetailsDto.startTime != null">
- and a.ALARM_START_TIME >=#{alarmDetailsDto.startTime}
- </if>
- <if test="alarmDetailsDto.endTime != null">
- and a.ALARM_START_TIME <=DATE_ADD(#{alarmDetailsDto.endTime},INTERVAL 1 DAY)
- </if>
- <if test="alarmDetailsDto.userType!=null and alarmDetailsDto.userType!=-999 and alarmDetailsDto.userType!=-9999 and alarmDetailsDto.programItems != null and alarmDetailsDto.programItems.size() > 0">
- <if test="alarmDetailsDto.permissonType == 5 or alarmDetailsDto.permissonType == 2">
- and ( a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- or
- a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- )
- </if>
- <if test="alarmDetailsDto.permissonType == 4 or alarmDetailsDto.permissonType == 3">
- and a.DEPT_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- </if>
- <if test="alarmDetailsDto.permissonType == 1">
- and a.COMPANY_ORG_ID in
- <foreach collection="alarmDetailsDto.programItems" item="item" open="(" close=")" separator=",">
- #{item.orgId}
- </foreach>
- and (a.DEPT_ORG_ID is null or a.DEPT_ORG_ID =0)
- </if>
- </if>
- </select>
- <select id="selectDeviceForCheckAlarm" resultType="com.huaxu.dto.DeviceStateAlarmDto">
- select
- d.TENANT_ID as "tenantId"
- ,d.id as "deviceId"
- ,d.COMPANY_ORG_ID as "companyOrgId"
- ,d.DEPT_ORG_ID as "deptOrgId"
- ,a.ALARM_TYPE as "alarmType"
- ,a.ATTRIBUTE_ID as "attributeId"
- ,d.LAST_UPDATE_TIME as "lastUpdateTime"
- ,timestampdiff(MINUTE,d.LAST_UPDATE_TIME,now()) as "duration"
- ,a.ALARM_CONDITION as "alarmCondition"
- ,a.ALARM_VALUE as "alarmValue"
- from sms_device d
- left join sms_alarm_setting a on a.DEVICE_ID =d.ID and a.ALARM_TYPE ='状态报警'
- </select>
- <select id="selectStateAlarm" resultType="com.huaxu.dto.AlarmDetailsDto">
- select
- id as "id"
- ,ALARM_VALUE as "alarmValue"
- ,ALARM_CONTENT as "alarmContent"
- ,ALARM_START_TIME as "alarmStartTime"
- ,max_value as "maxValue"
- ,min_value as "minValue"
- from sms_alarm_details where ALARM_TYPE='状态报警' and STATE = 1 and status = 1
- </select>
- </mapper>
|