兼容海康不规范的xml,大幅度提高通道分页查询速度,优化节点的保活。
This commit is contained in:
@@ -397,12 +397,6 @@ public interface IVideoManagerStorager {
|
||||
*/
|
||||
void updateParentPlatformStatus(String platformGbID, boolean online);
|
||||
|
||||
/**
|
||||
* 更新媒体节点
|
||||
* @param mediaServerItem
|
||||
*/
|
||||
void updateMediaServer(MediaServerItem mediaServerItem);
|
||||
|
||||
/**
|
||||
* 根据媒体ID获取启用/不启用的代理列表
|
||||
* @param id 媒体ID
|
||||
|
||||
@@ -56,27 +56,21 @@ public interface DeviceChannelMapper {
|
||||
|
||||
@Select(value = {" <script>" +
|
||||
"SELECT " +
|
||||
"dc1.*, " +
|
||||
"COUNT(dc2.channelId) as subCount " +
|
||||
"dc.* " +
|
||||
"from " +
|
||||
"device_channel dc1 " +
|
||||
"left join device_channel dc2 on " +
|
||||
"dc1.channelId = dc2.parentId " +
|
||||
"device_channel dc " +
|
||||
"WHERE " +
|
||||
"dc1.deviceId = #{deviceId} " +
|
||||
" <if test='query != null'> AND (dc1.channelId LIKE '%${query}%' OR dc1.name LIKE '%${query}%' OR dc1.name LIKE '%${query}%')</if> " +
|
||||
" <if test='parentChannelId != null'> AND dc1.parentId=#{parentChannelId} </if> " +
|
||||
" <if test='online == true' > AND dc1.status=1</if>" +
|
||||
" <if test='online == false' > AND dc1.status=0</if>" +
|
||||
" <if test='hasSubChannel == true' > AND subCount >0</if>" +
|
||||
" <if test='hasSubChannel == false' > AND subCount=0</if>" +
|
||||
"GROUP BY dc1.channelId " +
|
||||
"dc.deviceId = #{deviceId} " +
|
||||
" <if test='query != null'> AND (dc.channelId LIKE '%${query}%' OR dc.name LIKE '%${query}%' OR dc.name LIKE '%${query}%')</if> " +
|
||||
" <if test='parentChannelId != null'> AND dc.parentId=#{parentChannelId} </if> " +
|
||||
" <if test='online == true' > AND dc.status=1</if>" +
|
||||
" <if test='online == false' > AND dc.status=0</if>" +
|
||||
" <if test='hasSubChannel == true' > AND dc.subCount > 0 </if>" +
|
||||
" <if test='hasSubChannel == false' > AND dc.subCount = 0 </if>" +
|
||||
"GROUP BY dc.channelId " +
|
||||
" </script>"})
|
||||
List<DeviceChannel> queryChannels(String deviceId, String parentChannelId, String query, Boolean hasSubChannel, Boolean online);
|
||||
|
||||
@Select("SELECT * FROM device_channel WHERE deviceId=#{deviceId}")
|
||||
List<DeviceChannel> queryChannelsByDeviceId(String deviceId);
|
||||
|
||||
@Select("SELECT * FROM device_channel WHERE deviceId=#{deviceId} AND channelId=#{channelId}")
|
||||
DeviceChannel queryChannel(String deviceId, String channelId);
|
||||
|
||||
@@ -100,7 +94,7 @@ public interface DeviceChannelMapper {
|
||||
"dc.name, " +
|
||||
"de.manufacturer, " +
|
||||
"de.hostAddress, " +
|
||||
"(SELECT count(0) FROM device_channel WHERE parentId = dc.channelId) as subCount, " +
|
||||
"dc.subCount, " +
|
||||
"pgc.platformId as platformId, " +
|
||||
"pgc.catalogId as catalogId " +
|
||||
"FROM device_channel dc " +
|
||||
@@ -130,13 +124,13 @@ public interface DeviceChannelMapper {
|
||||
|
||||
@Insert("<script> " +
|
||||
"insert into device_channel " +
|
||||
"(channelId, deviceId, name, manufacture, model, owner, civilCode, block, " +
|
||||
"(channelId, deviceId, name, manufacture, model, owner, civilCode, block, subCount, " +
|
||||
" address, parental, parentId, safetyWay, registerWay, certNum, certifiable, errCode, secrecy, " +
|
||||
" ipAddress, port, password, PTZType, status, streamId, longitude, latitude, createTime, updateTime) " +
|
||||
"values " +
|
||||
"<foreach collection='addChannels' index='index' item='item' separator=','> " +
|
||||
"('${item.channelId}', '${item.deviceId}', '${item.name}', '${item.manufacture}', '${item.model}', " +
|
||||
"'${item.owner}', '${item.civilCode}', '${item.block}'," +
|
||||
"'${item.owner}', '${item.civilCode}', '${item.block}',${item.subCount}," +
|
||||
"'${item.address}', ${item.parental}, '${item.parentId}', ${item.safetyWay}, ${item.registerWay}, " +
|
||||
"'${item.certNum}', ${item.certifiable}, ${item.errCode}, '${item.secrecy}', " +
|
||||
"'${item.ipAddress}', ${item.port}, '${item.password}', ${item.PTZType}, ${item.status}, " +
|
||||
@@ -156,6 +150,7 @@ public interface DeviceChannelMapper {
|
||||
"<if test='item.owner != null'>, owner='${item.owner}'</if>" +
|
||||
"<if test='item.civilCode != null'>, civilCode='${item.civilCode}'</if>" +
|
||||
"<if test='item.block != null'>, block='${item.block}'</if>" +
|
||||
"<if test='item.subCount != null'>, block=${item.subCount}</if>" +
|
||||
"<if test='item.address != null'>, address='${item.address}'</if>" +
|
||||
"<if test='item.parental != null'>, parental=${item.parental}</if>" +
|
||||
"<if test='item.parentId != null'>, parentId='${item.parentId}'</if>" +
|
||||
@@ -182,21 +177,17 @@ public interface DeviceChannelMapper {
|
||||
|
||||
@Select(value = {" <script>" +
|
||||
"SELECT " +
|
||||
"dc1.*, " +
|
||||
"COUNT(dc2.channelId) as subCount " +
|
||||
"dc1.* " +
|
||||
"from " +
|
||||
"device_channel dc1 " +
|
||||
"left join device_channel dc2 on " +
|
||||
"dc1.channelId = dc2.parentId " +
|
||||
"WHERE " +
|
||||
"dc1.deviceId = #{deviceId} " +
|
||||
" <if test='query != null'> AND (dc1.channelId LIKE '%${query}%' OR dc1.name LIKE '%${query}%' OR dc1.name LIKE '%${query}%')</if> " +
|
||||
" <if test='parentChannelId != null'> AND dc1.parentId=#{parentChannelId} </if> " +
|
||||
" <if test='online == true' > AND dc1.status=1</if>" +
|
||||
" <if test='online == false' > AND dc1.status=0</if>" +
|
||||
" <if test='hasSubChannel == true' > AND subCount >0</if>" +
|
||||
" <if test='hasSubChannel == false' > AND subCount=0</if>" +
|
||||
"GROUP BY dc1.channelId " +
|
||||
" <if test='hasSubChannel == true' > AND dc1.subCount >0</if>" +
|
||||
" <if test='hasSubChannel == false' > AND dc1.subCount=0</if>" +
|
||||
"ORDER BY dc1.channelId ASC " +
|
||||
"Limit #{limit} OFFSET #{start}" +
|
||||
" </script>"})
|
||||
|
||||
@@ -1,10 +1,7 @@
|
||||
package com.genersoft.iot.vmp.storager.dao;
|
||||
|
||||
import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem;
|
||||
import org.apache.ibatis.annotations.Insert;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
import org.apache.ibatis.annotations.Select;
|
||||
import org.apache.ibatis.annotations.Update;
|
||||
import org.apache.ibatis.annotations.*;
|
||||
import org.springframework.stereotype.Repository;
|
||||
|
||||
import java.util.List;
|
||||
@@ -122,14 +119,14 @@ public interface MediaServerMapper {
|
||||
@Select("SELECT * FROM media_server")
|
||||
List<MediaServerItem> queryAll();
|
||||
|
||||
@Select("DELETE FROM media_server WHERE id='${id}'")
|
||||
@Delete("DELETE FROM media_server WHERE id='${id}'")
|
||||
void delOne(String id);
|
||||
|
||||
@Select("DELETE FROM media_server WHERE ip='${host}' and httpPort=${port}")
|
||||
void delOneByIPAndPort(String host, int port);
|
||||
|
||||
@Select("DELETE FROM media_server WHERE defaultServer=1;")
|
||||
void delDefault();
|
||||
@Delete("DELETE FROM media_server WHERE defaultServer=1")
|
||||
int delDefault();
|
||||
|
||||
@Select("SELECT * FROM media_server WHERE ip='${host}' and httpPort=${port}")
|
||||
MediaServerItem queryOneByHostAndPort(String host, int port);
|
||||
|
||||
@@ -174,7 +174,7 @@ public class VideoManagerStoragerImpl implements IVideoManagerStorager {
|
||||
List<DeviceChannel> updateChannels = new ArrayList<>();
|
||||
HashMap<String, DeviceChannel> channelsInStore = new HashMap<>();
|
||||
if (channels != null && channels.size() > 0) {
|
||||
List<DeviceChannel> channelList = deviceChannelMapper.queryChannelsByDeviceId(deviceId);
|
||||
List<DeviceChannel> channelList = deviceChannelMapper.queryChannels(deviceId, null, null, null, null);
|
||||
if (channelList.size() == 0) {
|
||||
for (DeviceChannel channel : channels) {
|
||||
channel.setDeviceId(deviceId);
|
||||
@@ -239,6 +239,7 @@ public class VideoManagerStoragerImpl implements IVideoManagerStorager {
|
||||
// 数据去重
|
||||
List<DeviceChannel> channels = new ArrayList<>();
|
||||
StringBuilder stringBuilder = new StringBuilder();
|
||||
Map<String, Integer> subContMap = new HashMap<>();
|
||||
if (deviceChannelList.size() > 1) {
|
||||
// 数据去重
|
||||
Set<String> gbIdSet = new HashSet<>();
|
||||
@@ -246,10 +247,26 @@ public class VideoManagerStoragerImpl implements IVideoManagerStorager {
|
||||
if (!gbIdSet.contains(deviceChannel.getChannelId())) {
|
||||
gbIdSet.add(deviceChannel.getChannelId());
|
||||
channels.add(deviceChannel);
|
||||
if (!StringUtils.isEmpty(deviceChannel.getParentId())) {
|
||||
if (subContMap.get(deviceChannel.getParentId()) == null) {
|
||||
subContMap.put(deviceChannel.getParentId(), 1);
|
||||
}else {
|
||||
Integer count = subContMap.get(deviceChannel.getParentId());
|
||||
subContMap.put(deviceChannel.getParentId(), count++);
|
||||
}
|
||||
}
|
||||
}else {
|
||||
stringBuilder.append(deviceChannel.getChannelId() + ",");
|
||||
}
|
||||
}
|
||||
if (channels.size() > 0) {
|
||||
for (DeviceChannel channel : channels) {
|
||||
if (subContMap.get(channel.getChannelId()) != null){
|
||||
channel.setSubCount(subContMap.get(channel.getChannelId()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}else {
|
||||
channels = deviceChannelList;
|
||||
}
|
||||
@@ -854,18 +871,6 @@ public class VideoManagerStoragerImpl implements IVideoManagerStorager {
|
||||
platformMapper.updateParentPlatformStatus(platformGbID, online);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateMediaServer(MediaServerItem mediaServerItem) {
|
||||
String now = this.format.format(System.currentTimeMillis());
|
||||
mediaServerItem.setUpdateTime(now);
|
||||
if (mediaServerMapper.queryOne(mediaServerItem.getId()) != null) {
|
||||
mediaServerMapper.update(mediaServerItem);
|
||||
}else {
|
||||
mediaServerItem.setCreateTime(now);
|
||||
mediaServerMapper.add(mediaServerItem);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<StreamProxyItem> getStreamProxyListForEnableInMediaServer(String id, boolean enable, boolean status) {
|
||||
return streamProxyMapper.selectForEnableInMediaServer(id, enable, status);
|
||||
|
||||
Reference in New Issue
Block a user