|  |  | 
 |  |  |  | 
 |  |  | import com.genersoft.iot.vmp.gb28181.bean.Device; | 
 |  |  | import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; | 
 |  |  | import com.genersoft.iot.vmp.gb28181.bean.PlatformCatalog; | 
 |  |  | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.ChannelReduce; | 
 |  |  | import org.apache.ibatis.annotations.Delete; | 
 |  |  | import org.apache.ibatis.annotations.Insert; | 
 |  |  | 
 |  |  |     List<String> findChannelRelatedPlatform(String platformId, List<String> deviceAndChannelIds); | 
 |  |  |  | 
 |  |  |     @Insert("<script> "+ | 
 |  |  |             "INSERT INTO platform_gb_channel (channelId, deviceId, platformId, deviceAndChannelId) VALUES" + | 
 |  |  |             "<foreach collection='channelReducesToAdd'  item='item' separator=','> ('${item.channelId}','${item.deviceId}', '${platformId}', '${item.deviceId}_${item.channelId}' )</foreach>" + | 
 |  |  |             "INSERT INTO platform_gb_channel (channelId, deviceId, platformId, deviceAndChannelId, catalogId) VALUES" + | 
 |  |  |             "<foreach collection='channelReducesToAdd'  item='item' separator=','>" + | 
 |  |  |             " ('${item.channelId}','${item.deviceId}', '${platformId}', '${item.deviceId}_${item.channelId}' , '${item.catalogId}' )" + | 
 |  |  |             "</foreach>" + | 
 |  |  |             "</script>") | 
 |  |  |     int addChannels(String platformId, List<ChannelReduce> channelReducesToAdd); | 
 |  |  |  | 
 |  |  | 
 |  |  |             "platformId='${platformId}' AND channelId='${channelId}' ) AND channelId='${channelId}'") | 
 |  |  |     DeviceChannel queryChannelInParentPlatform(String platformId, String channelId); | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     @Select("select dc.channelId as id, dc.name as name, pgc.platformId as platformId, pgc.catalogId as parentId, 0 as childrenCount, 1 as type " + | 
 |  |  |             "from device_channel dc left join platform_gb_channel pgc on dc.deviceId = pgc.deviceId and dc.channelId = pgc.channelId " + | 
 |  |  |             "where pgc.platformId=#{platformId} and pgc.catalogId=#{catalogId}") | 
 |  |  |     List<PlatformCatalog> queryChannelInParentPlatformAndCatalog(String platformId, String catalogId); | 
 |  |  |  | 
 |  |  |     @Select("SELECT * FROM device WHERE deviceId = (SELECT deviceId FROM platform_gb_channel WHERE platformId='${platformId}' AND channelId='${channelId}')") | 
 |  |  |     Device queryVideoDeviceByPlatformIdAndChannelId(String platformId, String channelId); | 
 |  |  |  | 
 |  |  |     @Delete("<script> "+ | 
 |  |  |             "DELETE FROM platform_gb_channel WHERE catalogId=#{id}"  + | 
 |  |  |             "</script>") | 
 |  |  |     int delByCatalogId(String id); | 
 |  |  |  | 
 |  |  |     @Delete("<script> "+ | 
 |  |  |            "DELETE FROM platform_gb_channel WHERE catalogId=#{parentId} AND platformId=#{platformId} AND channelId=#{id}"  + | 
 |  |  |            "</script>") | 
 |  |  |     int delByCatalogIdAndChannelIdAndPlatformId(PlatformCatalog platformCatalog); | 
 |  |  | } |