t1.id scene_Id,
t1.scene_name ,
t1.point_x ,
t1.point_y,
t1.address ,
if (t7.alarm_count>0, 1, 0) scene_state,
t5.device_id,
t5.attribute_id ,
ifnull(t5.remark, t5.`name`) attribute_name,
t5.unit ,
case when t5.attribute_id is null then null when t6.id is null then 0 else 1 end is_alarm,
t5.attribute_type,
if (t5.device_id is null, null, t4.device_code) device_code
inner join sms_scene t2 on find_in_set(t1.id, t2.parent_scene_ids) and t2. status = 1
inner join sms_scene_type t3 on t3.id = t1.scene_type_id and t3. status = 1
left join sms_device t4 on t4.scene_id=t2.id
select a1.device_id,a1.attribute_id,a1.remark,a1.seq,a2.name,a2.unit,a2.attribute_type
from sms_device_parm a1
inner join sms_device_attribute a2 on a1.attribute_id=a2.id
where a1. status = 1 and a2.status = 1
inner join sms_alarm_details t6 on t6.device_id=t4.id and t6. status = 1
left join (
select substring_index(substring_index(a3.parent_scene_ids, ',', 2), ',', -1) one_scene_id,count(1) alarm_count
from sms_device a1
inner join sms_alarm_details a2 on a1.id=a2.device_id and a2.`status` = 1 and a2.state = 1
inner join sms_scene a3 on a3.id=a1.scene_id and a3.`status` = 1
where a1.`status` = 1 group by one_scene_id
)t7 on t7.one_scene_id=t1.id