吉安感知网项目-后端
linwei
2026-04-02 b954d7a119eb635394bf4ff3619a9ab4b4978e48
sql改造首页
1 files modified
52 ■■■■ changed files
drone-service/drone-fw/src/main/java/org/sxkj/fw/device/mapper/FwDeviceMapper.xml 52 ●●●● patch | view | raw | blame | history
drone-service/drone-fw/src/main/java/org/sxkj/fw/device/mapper/FwDeviceMapper.xml
@@ -128,7 +128,7 @@
                    </foreach>
                    and ad.device_ids is not null
                    and ad.device_ids != ''
                    and find_in_set(ja_fw_device.id, ad.device_ids)
                    and ja_fw_device.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                        )
                    )
                </when>
@@ -143,7 +143,7 @@
                            and ad.id = #{areaId}
                            and ad.device_ids is not null
                            and ad.device_ids != ''
                            and find_in_set(ja_fw_device.id, ad.device_ids)
                            and ja_fw_device.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                            )
                            or not exists (
                            select 1
@@ -151,7 +151,7 @@
                            where ad.is_deleted = 0
                            and ad.device_ids is not null
                            and ad.device_ids != ''
                            and find_in_set(ja_fw_device.id, ad.device_ids)
                            and ja_fw_device.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                            and ad.id != #{areaId}
                            )
                        </when>
@@ -162,7 +162,7 @@
                            where ad.is_deleted = 0
                            and ad.device_ids is not null
                            and ad.device_ids != ''
                            and find_in_set(ja_fw_device.id, ad.device_ids)
                            and ja_fw_device.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                            )
                        </otherwise>
                    </choose>
@@ -197,7 +197,7 @@
                                  and ad.id = #{query.areaId}
                                  and ad.device_ids is not null
                                  and ad.device_ids != ''
                                  and find_in_set(ja_fw_device.id, ad.device_ids)
                                  and ja_fw_device.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                            )
                            or not exists (
                                select 1
@@ -205,7 +205,7 @@
                                where ad.is_deleted = 0
                                  and ad.device_ids is not null
                                  and ad.device_ids != ''
                                  and find_in_set(ja_fw_device.id, ad.device_ids)
                                  and ja_fw_device.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                                  and ad.id != #{query.areaId}
                            )
                        </when>
@@ -216,7 +216,7 @@
                                where ad.is_deleted = 0
                                  and ad.device_ids is not null
                                  and ad.device_ids != ''
                                  and find_in_set(ja_fw_device.id, ad.device_ids)
                                  and ja_fw_device.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                            )
                        </otherwise>
                    </choose>
@@ -276,7 +276,7 @@
            FROM
                ja_fw_device d
            LEFT JOIN ja_fw_area_divide ad
                ON find_in_set(d.id, ad.device_ids) > 0
                ON d.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                AND ad.is_deleted = 0
            WHERE
                d.is_deleted = 0
@@ -302,7 +302,7 @@
                where ds.is_deleted = 0
                and ds.area_divide_ids is not null
                and ds.area_divide_ids != ''
                and find_in_set(ad.id, replace(ds.area_divide_ids, ' ', ''))
                and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
                and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{flyTime})
                and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{flyTime})
                )
@@ -322,7 +322,7 @@
            FROM
                ja_fw_device d
            LEFT JOIN ja_fw_area_divide ad
                ON find_in_set(d.id, ad.device_ids) > 0
                ON d.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                AND ad.is_deleted = 0
            WHERE
                d.is_deleted = 0
@@ -349,7 +349,7 @@
                where ds.is_deleted = 0
                and ds.area_divide_ids is not null
                and ds.area_divide_ids != ''
                and find_in_set(ad.id, replace(ds.area_divide_ids, ' ', ''))
                and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
                and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{flyTime})
                and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{flyTime})
                )
@@ -456,7 +456,7 @@
             FROM
                 ja_fw_device d
            left join ja_fw_area_divide ad
                on find_in_set(d.id, ad.device_ids) > 0
                on d.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                and ad.is_deleted = 0
             WHERE
                 d.is_deleted = 0
@@ -481,7 +481,7 @@
                    where ds.is_deleted = 0
                    and ds.area_divide_ids is not null
                    and ds.area_divide_ids != ''
                    and find_in_set(ad.id, replace(ds.area_divide_ids, ' ', ''))
                    and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
                    and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{flyTime})
                    and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{flyTime})
                    )
@@ -493,7 +493,7 @@
             FROM
                 ja_fw_device d
            left join ja_fw_area_divide ad
                on find_in_set(d.id, ad.device_ids) > 0
                on d.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                and ad.is_deleted = 0
             WHERE
                 d.is_deleted = 0
@@ -519,7 +519,7 @@
                    where ds.is_deleted = 0
                    and ds.area_divide_ids is not null
                    and ds.area_divide_ids != ''
                    and find_in_set(ad.id, replace(ds.area_divide_ids, ' ', ''))
                    and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
                    and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{flyTime})
                    and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{flyTime})
                    )
@@ -531,7 +531,7 @@
             FROM
                 ja_fw_device d
            left join ja_fw_area_divide ad
                on find_in_set(d.id, ad.device_ids) > 0
                on d.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                and ad.is_deleted = 0
             WHERE d.is_deleted = 0
               and d.is_enabled = 1
@@ -556,7 +556,7 @@
                where ds.is_deleted = 0
                and ds.area_divide_ids is not null
                and ds.area_divide_ids != ''
                and find_in_set(ad.id, replace(ds.area_divide_ids, ' ', ''))
                and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
                and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{flyTime})
                and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{flyTime})
                )
@@ -567,7 +567,7 @@
                 COUNT(*)
             FROM ja_fw_device d
             left join ja_fw_area_divide ad
                on find_in_set(d.id, ad.device_ids) > 0
                on d.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                and ad.is_deleted = 0
             WHERE d.is_deleted = 0
               and d.is_enabled = 1
@@ -592,7 +592,7 @@
                    where ds.is_deleted = 0
                    and ds.area_divide_ids is not null
                    and ds.area_divide_ids != ''
                    and find_in_set(ad.id, replace(ds.area_divide_ids, ' ', ''))
                    and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
                    and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{flyTime})
                    and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{flyTime})
                    )
@@ -603,7 +603,7 @@
                 COUNT(*)
             FROM ja_fw_device d
            left join ja_fw_area_divide ad
                on find_in_set(d.id, ad.device_ids) > 0
                on d.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
                and ad.is_deleted = 0
             WHERE d.is_deleted = 0
               and d.is_enabled = 1
@@ -628,7 +628,7 @@
                    where ds.is_deleted = 0
                    and ds.area_divide_ids is not null
                    and ds.area_divide_ids != ''
                    and find_in_set(ad.id, replace(ds.area_divide_ids, ' ', ''))
                    and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
                    and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{flyTime})
                    and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{flyTime})
                    )
@@ -644,10 +644,10 @@
        from
            ja_fw_device d
        left join ja_fw_area_divide ad
            on find_in_set(d.id, ad.device_ids) > 0
            on d.id = ANY(string_to_array(ad.device_ids, ',')::bigint[])
            and ad.is_deleted = 0
        left join ja_fw_defense_scene ds
            on find_in_set(ad.id, ds.area_divide_ids) > 0
            on ad.id = ANY(string_to_array(ds.area_divide_ids, ',')::bigint[])
            and ds.is_deleted = 0
        left join ja_fw_defense_scene_manage dsm
            on dsm.defense_scene_id = ds.id::VARCHAR
@@ -663,7 +663,7 @@
                where ds.is_deleted = 0
                and ds.area_divide_ids is not null
                and ds.area_divide_ids != ''
                and find_in_set(ad.id, replace(ds.area_divide_ids, ' ', ''))
                and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
                and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{param2.flyTime})
                and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{param2.flyTime})
                )
@@ -797,8 +797,8 @@
            and ds.area_divide_ids is not null
            and ds.area_divide_ids != ''
            and ad.id = ANY(string_to_array(replace(ds.area_divide_ids, ' ', ''), ',')::bigint[])
            and dsm.effective_date_start &lt;= #{flyTime}::timestamp
            and dsm.effective_date_end &gt;= #{flyTime}::timestamp
            and (dsm.effective_date_start is null or dsm.effective_date_start &lt;= #{flyTime}::timestamp)
            and (dsm.effective_date_end is null or dsm.effective_date_end &gt;= #{flyTime}::timestamp)
            )
        </if>
        GROUP BY