t1.id scene_Id,
t1.scene_name ,
t1.point_x ,
t1.point_y,
t1.address ,
t5.device_id,
t5.attribute_id ,
ifnull(t5.remark, t9.`name`) attribute_name,
t9.unit ,
case when t5.attribute_id is null then null when t6.id is null then 0 else 1 end is_alarm,
t5.parm_type attribute_type,
if (t5.device_id is null, null, t4.device_code) device_code
inner join sms_scene_type t3 on t3.id = t1.scene_type_id and t3. status = 1
left join sms_device_scene t2 on t2.parent_scene_id=t1.id and t2. status = 1
left join sms_device t4 on t2.device_id=t4.id and t4. status = 1 and t4. enable_state = 1
left join sms_device_parm t5 on t5.scene_id = t2.scene_id and t5.device_id=t2.device_id and t5. status = 1
and t5.is_suspension = 1
and t5.is_map = 1
left join sms_device_attribute t9 on t5.attribute_id=t9.id and t9.status = 1
left join sms_alarm_details t6 on t6.scene_id=t2.scene_id and t6.device_id=t2.device_id
and t6.attribute_id=t5.attribute_id and t6.status = 1 and t6.state=1
left join (
select parent_scene_id,count(1) alarm_count
from sms_alarm_details a1
where a1.`status` = 1 and a1.state = 1
and a1.scene_id in
#{item}
group by parent_scene_id
)t7 on t7.parent_scene_id=t1.id
select
t1.scene_name as "sceneName",
t6.alarm_content as "alarmContent",
t6.alarm_start_time as "alarmStartTime"
from sms_scene t1
inner join sms_scene_type t3 on t3.id = t1.scene_type_id and t3. status = 1
inner join sms_alarm_details t6 on t1.id=t6.parent_scene_id and t6.`status`=1
where t1.parent_scene_id = 0 and t1. status = 1 and t1. enable_state = 1 and t3.scene_type_name = #{sceneTypeName} and t6.state=1
and t1.id in
#{item}
and t1.id is null
and t1.scene_name like concat('%',#{sceneName},'%')
and t1.tenant_id = #{tenantId}
order by t6.alarm_start_time desc
select
t1.scene_name as "sceneName",
count(1) as "alalmCount"
from sms_scene t1
inner join sms_scene_type t3 on t3.id = t1.scene_type_id and t3. status = 1
inner join sms_alarm_details t6 on t1.id=t6.parent_scene_id and t6.`status`=1
where t1.parent_scene_id = 0 and t1. status = 1 and t1. enable_state = 1 and t3.scene_type_name = #{sceneTypeName} and t6.state=1
and t1.id in
#{item}
and t1.id is null
and t1.scene_name like concat('%',#{sceneName},'%')
and t1.tenant_id = #{tenantId}
group by t1.scene_name
order by alalmCount desc
select
,if (t7.alarm_count>0, 1, 0) scene_state
from sms_scene t1
where t1.parent_scene_id = 0 and t1. status = 1 and t1. enable_state = 1 and t3.scene_type_name = #{sceneTypeName}
and t1.id in
#{item}
and t1.id is null
and t1.tenant_id = #{tenantId}
order by t1.scene_name,t5.seq
select
from sms_scene t1
where t1.parent_scene_id = 0 and t1. status = 1 and t1.id = #{sceneId}
and t1.id in
#{item}
order by t1.scene_name,t5.seq
select t1.id scene_id,t1.scene_name,t1.address
from sms_scene t1
inner join sms_scene_type t3 on t3.id = t1.scene_type_id and t3. status = 1
where t1.parent_scene_id = 0 and t1. status = 1 and t1. enable_state = 1 and t3.scene_type_name = #{onlineDataDto.sceneTypeName}
and t1.id in
#{item}
and t1.id is null
and t1.scene_name like concat('%',#{onlineDataDto.sceneName},'%')
and t1.tenant_id = #{onlineDataDto.tenantId}
order by t1.date_create
select
t4.id,
t4.device_name as "deviceName",
count(1) as "alarmCount",
sum(timestampdiff(minute,t6.alarm_start_time,ifnull(t6.alarm_end_time,now()))) as "alarmDuration"
from sms_scene t1
inner join sms_scene_type t3 on t3.id = t1.scene_type_id and t3. status = 1
inner join sms_alarm_details t6 on t1.id=t6.parent_scene_id and t6.`status`=1
inner join sms_device t4 on t4.id=t6.device_id and t4.`status`=1 and t4. enable_state = 1
where t1.parent_scene_id = 0 and t1. status = 1 and t1. enable_state = 1 and t1.id = #{id}
and t1.id in
#{item}
and t6.alarm_start_time>DATE(NOW() + INTERVAL-#{days}+1 DAY)
group by t4.id,t4.device_name
select
,t8.latest_value
from sms_scene t1
left join (
select b1.device_id,b1.attribute_id,max(latest_value) latest_value
from sms_day_report b1
where b1.year = year(now() + interval-1 day) and b1.month = month(now() + interval-1 day) and b1.day = day(now() + interval-1 day)
group by b1.device_id,b1.attribute_id
)t8 on t8.device_id=t2.device_id and t8.attribute_id =t5.attribute_id
where t1.parent_scene_id = 0 and t1. status = 1
and t5.parm_type in(3,4,5,6)
and t5.parm_type in(2,3,4,5,6,7,8,9,10,11,12,13,14)
and t3.scene_type_name = #{sceneTypeName}
and t1.id = #{sceneId}
and t1.id in
#{item}
and t1.tenant_id = #{tenantId}
order by t1.scene_name,t5.seq
select t1.id,t1.scene_name sceneName,sum(if(t5.id is null,0,1)) deviceCount
from sms_scene t1
inner join sms_scene_type t3 on t1.scene_type_id=t3.id and t3. status = 1
left join sms_device_scene t2 on t2.parent_scene_id=t1.id and t2. status = 1
left join sms_device t6 on t2.device_id=t6.id and t6. status = 1
left join sms_scene t4 on t2.scene_id=t4.id and t4. status = 1
left join sms_scene_type t5 on t4.scene_type_id=t5.id and t5. status = 1 and t5.scene_type_name = #{sceneTypeName}
where t1.parent_scene_id = 0 and t1. status = 1 and t1. enable_state = 1 and t3.scene_type_name = '管网'
and t1.id in
#{item}
and t1.id is null
and t1.id = #{sceneId}
and t6.device_name like concat('%', #{deviceName},'%')
group by t1.id,t1.scene_name
select distinct t1.id device_id,t1.device_code,t1.device_name,t1.point_x,point_y,t1.address,t2.attribute_id, ifnull(t2.remark, t3.`name`) attribute_name,t3.unit,
case when t2.attribute_id is null then null when t6.id is null then 0 else 1 end is_alarm, if (t4.alarm_count>0, 1, 0) scene_state
from sms_device t1
left join sms_device_parm t2 on t2.device_id=t1.id and t2.is_map=1
left join sms_device_attribute t3 on t2.attribute_id=t3.id
left join (
select a1.device_id,count(1) alarm_count from sms_alarm_details a1 where a1.device_id= #{deviceId} and a1.`status` = 1 and a1.state = 1
)t4 on t4.device_id=t1.id
left join sms_alarm_details t6 on t6.device_id=t1.id and t6.attribute_id=t2.attribute_id and t6.status = 1 and t6.state=1
where t1. status = 1 and t1. enable_state = 1 and t1.id= #{deviceId}