优化自动同步国标通道到通用通道,分组信息以及行政区划自动同步

结构优化
648540858 2023-10-06 23:39:38 +08:00
parent 6255e6f89f
commit 29352cc9cd
6 changed files with 203 additions and 110 deletions

View File

@ -48,17 +48,17 @@ public interface IGroupService {
/** /**
* *
*/ */
boolean updateChannelsToBusinessGroup(int id, List<CommonGbChannel> channels); boolean updateChannelsToGroup(int id, List<CommonGbChannel> channels);
/** /**
* *
*/ */
boolean updateChannelsToBusinessGroup(String deviceId, List<CommonGbChannel> channels); boolean updateChannelsToGroup(String deviceId, List<CommonGbChannel> channels);
/** /**
* *
*/ */
boolean removeChannelsFromBusinessGroup(List<CommonGbChannel> channels); boolean removeChannelsFromGroup(List<CommonGbChannel> channels);
} }

View File

@ -111,10 +111,10 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService {
Set<String> parentIdSet = new HashSet<>(); Set<String> parentIdSet = new HashSet<>();
// 存储得到的所有行政区划, 后续检验civilCode是否已传输对应的行政区划数据从而确定是否需要自动创建节点。 // 存储得到的所有行政区划, 后续检验civilCode是否已传输对应的行政区划数据从而确定是否需要自动创建节点。
Set<String> civilCodeSet = new HashSet<>(); Set<String> civilCodeSet = new HashSet<>();
List<DeviceChannel> clearChannels = new ArrayList<>(); List<String> clearChannels = new ArrayList<>();
deviceChannels.stream().forEach(deviceChannel -> { deviceChannels.stream().forEach(deviceChannel -> {
if (deviceChannel.getCommonGbChannelId() > 0) { if (deviceChannel.getCommonGbChannelId() > 0) {
clearChannels.add(deviceChannel); clearChannels.add(deviceChannel.getChannelId());
} }
Gb28181CodeType channelIdType = SipUtils.getChannelIdType(deviceChannel.getChannelId()); Gb28181CodeType channelIdType = SipUtils.getChannelIdType(deviceChannel.getChannelId());
if (channelIdType != null) { if (channelIdType != null) {
@ -155,6 +155,15 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService {
commonGbChannelList.add(commonGbChannel); commonGbChannelList.add(commonGbChannel);
} }
}); });
// 检查是否存在已存在通道与将写入通道相同的情况
List<CommonGbChannel> commonGbChannelInDbList = commonGbChannelMapper.queryInList(commonGbChannelList);
if (!commonGbChannelInDbList.isEmpty()) {
// 这里可以控制新数据覆盖旧数据还是丢弃重复的新数据
// 目前使用新数据覆盖旧数据,后续分局实际业务需求再做修改
commonGbChannelInDbList.stream().forEach(commonGbChannel->{
clearChannels.add(commonGbChannel.getCommonGbDeviceID());
});
}
TransactionStatus transactionStatus = dataSourceTransactionManager.getTransaction(transactionDefinition); TransactionStatus transactionStatus = dataSourceTransactionManager.getTransaction(transactionDefinition);
int limit = 50; int limit = 50;
if (!clearChannels.isEmpty()) { if (!clearChannels.isEmpty()) {
@ -166,7 +175,7 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService {
if (i + limit > clearChannels.size()) { if (i + limit > clearChannels.size()) {
toIndex = clearChannels.size(); toIndex = clearChannels.size();
} }
List<DeviceChannel> clearChannelsSun = clearChannels.subList(i, toIndex); List<String> clearChannelsSun = clearChannels.subList(i, toIndex);
int currentResult = commonGbChannelMapper.deleteByDeviceIDs(clearChannelsSun); int currentResult = commonGbChannelMapper.deleteByDeviceIDs(clearChannelsSun);
if (currentResult <= 0) { if (currentResult <= 0) {
dataSourceTransactionManager.rollback(transactionStatus); dataSourceTransactionManager.rollback(transactionStatus);
@ -206,7 +215,6 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService {
}else { }else {
virtuallyGroup.setCommonGroupTopId(topGroupId); virtuallyGroup.setCommonGroupTopId(topGroupId);
} }
} }
} }
@ -252,11 +260,7 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService {
// 处理存在错误的parentId // 处理存在错误的parentId
if (!errorParentIdList.isEmpty()) { if (!errorParentIdList.isEmpty()) {
if (errorParentIdList.size() <= limit) { if (errorParentIdList.size() <= limit) {
if (commonGbChannelMapper.clearParentIds(errorParentIdList) <= 0) { commonGbChannelMapper.clearParentIds(errorParentIdList);
dataSourceTransactionManager.rollback(transactionStatus);
logger.info("[同步通用通道]来自国标设备,失败, 处理错误的ParentId失败, 国标编号: {}", gbDeviceId);
return false;
}
} else { } else {
for (int i = 0; i < errorParentIdList.size(); i += limit) { for (int i = 0; i < errorParentIdList.size(); i += limit) {
int toIndex = i + limit; int toIndex = i + limit;
@ -264,17 +268,27 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService {
toIndex = errorParentIdList.size(); toIndex = errorParentIdList.size();
} }
List<String> errorParentIdListSub = errorParentIdList.subList(i, toIndex); List<String> errorParentIdListSub = errorParentIdList.subList(i, toIndex);
if (commonGbChannelMapper.clearParentIds(errorParentIdListSub) <= 0) { commonGbChannelMapper.clearParentIds(errorParentIdListSub);
dataSourceTransactionManager.rollback(transactionStatus);
logger.info("[同步通用通道]来自国标设备,失败, 处理错误的ParentId失败, 国标编号: {}", gbDeviceId);
return false;
}
} }
} }
} }
// 分组信息写入数据库 // 分组信息写入数据库
List<Group> allGroup = new ArrayList<>(businessGroupMap.values()); List<Group> allGroup = new ArrayList<>(businessGroupMap.values());
allGroup.addAll(virtuallyGroupMap.values()); allGroup.addAll(virtuallyGroupMap.values());
if (!allGroup.isEmpty()) {
// 这里也采取只插入新数据的方式
List<Group> groupInDBList = groupMapper.queryInList(allGroup);
if (!groupInDBList.isEmpty()) {
groupInDBList.stream().forEach(groupInDB -> {
for (int i = 0; i < allGroup.size(); i++) {
if (groupInDB.getCommonGroupDeviceId().equalsIgnoreCase(allGroup.get(i).getCommonGroupDeviceId())) {
allGroup.remove(i);
break;
}
}
});
}
if (!allGroup.isEmpty()) {
if (allGroup.size() <= limit) { if (allGroup.size() <= limit) {
if (groupMapper.addAll(allGroup) <= 0) { if (groupMapper.addAll(allGroup) <= 0) {
dataSourceTransactionManager.rollback(transactionStatus); dataSourceTransactionManager.rollback(transactionStatus);
@ -295,15 +309,39 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService {
} }
} }
} }
}
}
List<String> errorCivilCodeList = new ArrayList<>();
// 检测行政区划信息是否完整 // 检测行政区划信息是否完整
for (String civilCode : civilCodeSet) { for (String civilCode : civilCodeSet) {
if (!regionMap.containsKey(civilCode)) { if (!regionMap.containsKey(civilCode)) {
logger.warn("[通道信息中缺少地区信息]补充地区信息 国标编号: {} civilCode {}", gbDeviceId, civilCode ); logger.warn("[通道信息中缺少地区信息]补充地区信息 国标编号: {} civilCode {}", gbDeviceId, civilCode );
Region region = civilCodeFileConf.createRegion(civilCode); Region region = civilCodeFileConf.createRegion(civilCode);
if (region != null) {
regionMap.put(region.getCommonRegionDeviceId(), region); regionMap.put(region.getCommonRegionDeviceId(), region);
}else {
logger.warn("[获取地区信息]失败 国标编号: {} civilCode {}", gbDeviceId, civilCode );
errorCivilCodeList.add(civilCode);
}
} }
} }
if (!errorCivilCodeList.isEmpty()) {
if (errorCivilCodeList.size() <= limit) {
commonGbChannelMapper.clearCivilCodes(errorCivilCodeList);
} else {
for (int i = 0; i < errorCivilCodeList.size(); i += limit) {
int toIndex = i + limit;
if (i + limit > errorCivilCodeList.size()) {
toIndex = errorCivilCodeList.size();
}
List<String> errorCivilCodeListSub = errorParentIdList.subList(i, toIndex);
commonGbChannelMapper.clearCivilCodes(errorCivilCodeListSub);
}
}
}
// 行政区划信息写入数据库 // 行政区划信息写入数据库
List<Region> allRegion = new ArrayList<>(regionMap.values()); List<Region> allRegion = new ArrayList<>(regionMap.values());
if (!allRegion.isEmpty()) { if (!allRegion.isEmpty()) {
@ -543,7 +581,15 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService {
@Override @Override
public void deleteGbChannelsFromList(List<DeviceChannel> channelList) { public void deleteGbChannelsFromList(List<DeviceChannel> channelList) {
commonGbChannelMapper.deleteByDeviceIDs(channelList); if (channelList.isEmpty()) {
return;
}
List<String> channelIdList = new ArrayList<>(channelList.size());
for (DeviceChannel deviceChannel : channelList) {
channelIdList.add(deviceChannel.getChannelId());
}
commonGbChannelMapper.deleteByDeviceIDs(channelIdList);
} }
@Override @Override

View File

@ -24,7 +24,7 @@ public class GroupServiceImpl implements IGroupService {
private CommonGbChannelMapper commonGbChannelDao; private CommonGbChannelMapper commonGbChannelDao;
@Autowired @Autowired
private GroupMapper businessGroupDao; private GroupMapper groupMapper;
@Autowired @Autowired
DataSourceTransactionManager dataSourceTransactionManager; DataSourceTransactionManager dataSourceTransactionManager;
@ -35,105 +35,129 @@ public class GroupServiceImpl implements IGroupService {
@Override @Override
public List<Group> getNodes(String parentId) { public List<Group> getNodes(String parentId) {
return businessGroupDao.getNodes(parentId); return groupMapper.getNodes(parentId);
} }
@Override @Override
public List<CommonGbChannel> getChannels(int id) { public List<CommonGbChannel> getChannels(int id) {
Group businessGroup = businessGroupDao.query(id); Group group = groupMapper.query(id);
if (businessGroup == null) { if (group == null) {
return null; return null;
} }
return commonGbChannelDao.getChannels(businessGroup.getCommonBusinessGroupPath()); return commonGbChannelDao.getChannels(group.getCommonGroupDeviceId());
} }
@Override @Override
public List<CommonGbChannel> getChannels(String deviceId) { public List<CommonGbChannel> getChannels(String deviceId) {
Group businessGroup = businessGroupDao.queryByDeviceId(deviceId); Group group = groupMapper.queryByDeviceId(deviceId);
if (businessGroup == null) { if (group == null) {
return null; return null;
} }
return commonGbChannelDao.getChannels(businessGroup.getCommonBusinessGroupPath()); return commonGbChannelDao.getChannels(group.getCommonGroupDeviceId());
} }
@Override @Override
public boolean add(Group businessGroup) { public boolean add(Group group) {
return businessGroupDao.add(businessGroup) > 0; return groupMapper.add(group) > 0;
} }
@Override @Override
public boolean remove(int id) { public boolean remove(int id) {
return businessGroupDao.remove(id) > 0; return groupMapper.remove(id) > 0;
} }
@Override @Override
public boolean remove(String deviceId) { public boolean remove(String deviceId) {
return businessGroupDao.removeByDeviceId(deviceId) > 0; return groupMapper.removeByDeviceId(deviceId) > 0;
} }
@Override @Override
public boolean update(Group businessGroup) { public boolean update(Group group) {
if (businessGroup.getCommonBusinessGroupId() == 0) { if (group.getCommonGroupId() == 0) {
return false; return false;
} }
Group businessGroupInDb = businessGroupDao.query(businessGroup.getCommonBusinessGroupId()); return groupMapper.update(group) > 0;
if (businessGroupInDb == null) { }
@Override
public boolean updateChannelsToGroup(int id, List<CommonGbChannel> channels) {
if (channels.isEmpty()) {
return false; return false;
} }
Group group = groupMapper.query(id);
if (group == null) {
return false;
}
return updateChannelsToGroup(group, channels);
}
@Override
public boolean updateChannelsToGroup(String deviceId, List<CommonGbChannel> channels) {
if (channels.isEmpty()) {
return false;
}
Group group = groupMapper.queryByDeviceId(deviceId);
if (group == null) {
return false;
}
return updateChannelsToGroup(group, channels);
}
private boolean updateChannelsToGroup(Group group, List<CommonGbChannel> channels) {
for (CommonGbChannel channel : channels) {
channel.setCommonGbBusinessGroupID(group.getCommonGroupTopId());
channel.setCommonGbParentID(group.getCommonGroupDeviceId());
}
int limit = 50;
if (channels.size() <= limit) {
if (commonGbChannelDao.updateChanelForGroup(channels) <= 0) {
logger.info("[添加通道到分组] 失败");
return false;
}
} else {
TransactionStatus transactionStatus = dataSourceTransactionManager.getTransaction(transactionDefinition); TransactionStatus transactionStatus = dataSourceTransactionManager.getTransaction(transactionDefinition);
boolean result = false; for (int i = 0; i < channels.size(); i += limit) {
if (!businessGroupInDb.getCommonBusinessGroupPath().equals(businessGroup.getCommonBusinessGroupPath())) { int toIndex = i + limit;
// 需要更新通道信息 if (i + limit > channels.size()) {
int updateCount = commonGbChannelDao.updateBusinessGroupPath(businessGroupInDb.getCommonBusinessGroupPath(), businessGroup.getCommonBusinessGroupPath()); toIndex = channels.size();
if (updateCount > 0) { }
dataSourceTransactionManager.rollback(transactionStatus); List<CommonGbChannel> channelsSub = channels.subList(i, toIndex);
return false; if (commonGbChannelDao.updateChanelForGroup(channelsSub) <= 0) {
} else { dataSourceTransactionManager.rollback(transactionStatus);
result = businessGroupDao.update(businessGroup) > 0; logger.info("[添加通道到分组] 失败");
return false;
} }
} else {
result = businessGroupDao.update(businessGroup) > 0;
} }
dataSourceTransactionManager.commit(transactionStatus); dataSourceTransactionManager.commit(transactionStatus);
return result; }
return true;
} }
@Override @Override
public boolean updateChannelsToBusinessGroup(int id, List<CommonGbChannel> channels) { public boolean removeChannelsFromGroup(List<CommonGbChannel> channels) {
if (channels.isEmpty()) { int limit = 50;
if (channels.size() <= limit) {
if (commonGbChannelDao.removeChannelsForGroup(channels) <= 0) {
logger.info("[从分组移除通道] 失败");
return false; return false;
} }
Group businessGroup = businessGroupDao.query(id); } else {
if (businessGroup == null) { TransactionStatus transactionStatus = dataSourceTransactionManager.getTransaction(transactionDefinition);
for (int i = 0; i < channels.size(); i += limit) {
int toIndex = i + limit;
if (i + limit > channels.size()) {
toIndex = channels.size();
}
List<CommonGbChannel> channelsSub = channels.subList(i, toIndex);
if (commonGbChannelDao.removeChannelsForGroup(channelsSub) <= 0) {
dataSourceTransactionManager.rollback(transactionStatus);
logger.info("[从分组移除通道] 失败");
return false; return false;
} }
for (CommonGbChannel channel : channels) {
channel.setCommonGbBusinessGroupID(businessGroup.getCommonBusinessGroupPath());
} }
// TODO 增加对数量的判断,分批处理 dataSourceTransactionManager.commit(transactionStatus);
return commonGbChannelDao.updateChanelForBusinessGroup(channels) > 1;
} }
return true;
@Override
public boolean updateChannelsToBusinessGroup(String deviceId, List<CommonGbChannel> channels) {
if (channels.isEmpty()) {
return false;
}
Group businessGroup = businessGroupDao.queryByDeviceId(deviceId);
if (businessGroup == null) {
return false;
}
for (CommonGbChannel channel : channels) {
channel.setCommonGbBusinessGroupID(businessGroup.getCommonBusinessGroupPath());
}
// TODO 增加对数量的判断,分批处理
return commonGbChannelDao.updateChanelForBusinessGroup(channels) > 1;
}
@Override
public boolean removeChannelsFromBusinessGroup(List<CommonGbChannel> channels) {
// TODO 增加对数量的判断,分批处理
return commonGbChannelDao.removeChannelsForBusinessGroup(channels) > 1;
} }
} }

View File

@ -11,8 +11,8 @@ import java.util.List;
@Repository @Repository
public interface CommonGbChannelMapper { public interface CommonGbChannelMapper {
@Select(value = "select * from wvp_common_gb_channel where common_gb_business_group_id = '#{commonBusinessGroupPath}'") @Select(value = "select * from wvp_common_gb_channel where common_gb_business_group_id = '#{commonGroupId}'")
List<CommonGbChannel> getChannels(String commonBusinessGroupPath); List<CommonGbChannel> getChannels(String commonGroupId);
@Update(value = "<script>" + @Update(value = "<script>" +
"<foreach collection='channels' item='item' separator=';'>" + "<foreach collection='channels' item='item' separator=';'>" +
@ -55,7 +55,7 @@ public interface CommonGbChannelMapper {
" WHERE common_gb_id=#{item.commonGbId}" + " WHERE common_gb_id=#{item.commonGbId}" +
"</foreach>" + "</foreach>" +
"</script>") "</script>")
int updateChanelForBusinessGroup(List<CommonGbChannel> channels); int updateChanelForGroup(List<CommonGbChannel> channels);
@Delete(value = "<script>" + @Delete(value = "<script>" +
@ -63,10 +63,7 @@ public interface CommonGbChannelMapper {
"delete from wvp_common_gb_channel WHERE common_gb_id=#{item.commonGbId}" + "delete from wvp_common_gb_channel WHERE common_gb_id=#{item.commonGbId}" +
"</foreach>" + "</foreach>" +
"</script>") "</script>")
int removeChannelsForBusinessGroup(List<CommonGbChannel> channels); int removeChannelsForGroup(List<CommonGbChannel> channels);
@Update("update wvp_common_gb_channel set common_gb_business_group_id = #{newPath} where common_gb_business_group_id = #{oldPath}")
int updateBusinessGroupPath(String oldPath, String newPath);
@Select("select * from wvp_common_gb_channel where common_gb_device_id=#{channelId}") @Select("select * from wvp_common_gb_channel where common_gb_device_id=#{channelId}")
CommonGbChannel queryByDeviceID(String channelId); CommonGbChannel queryByDeviceID(String channelId);
@ -284,10 +281,11 @@ public interface CommonGbChannelMapper {
int addAll(List<CommonGbChannel> commonGbChannelList); int addAll(List<CommonGbChannel> commonGbChannelList);
@Delete("<script> "+ @Delete("<script> "+
"DELETE from wvp_common_gb_channel WHERE common_gb_id in" + "DELETE from wvp_common_gb_channel WHERE common_gb_device_id in (" +
"<foreach collection='clearChannels' item='item' open='(' separator=',' close=')' > #{item.commonGbChannelId}</foreach>" + "<foreach collection='clearChannels' item='item' separator=',' > #{item}</foreach>" +
" )"+
"</script>") "</script>")
int deleteByDeviceIDs(List<DeviceChannel> clearChannels); int deleteByDeviceIDs(List<String> clearChannels);
@Update("<script> "+ @Update("<script> "+
"UPDATE wvp_common_gb_channel SET commonGbStatus = true WHERE common_gb_id in" + "UPDATE wvp_common_gb_channel SET commonGbStatus = true WHERE common_gb_id in" +
@ -307,4 +305,16 @@ public interface CommonGbChannelMapper {
"<foreach collection='errorParentIdList' item='item' open='(' separator=',' close=')' > #{item}</foreach>" + "<foreach collection='errorParentIdList' item='item' open='(' separator=',' close=')' > #{item}</foreach>" +
"</script>") "</script>")
int clearParentIds(List<String> errorParentIdList); int clearParentIds(List<String> errorParentIdList);
@Update("<script> "+
"UPDATE wvp_common_gb_channel SET common_gb_civilCode = null WHERE common_gb_civilCode in" +
"<foreach collection='errorCivilCodeList' item='item' open='(' separator=',' close=')' > #{item}</foreach>" +
"</script>")
void clearCivilCodes(List<String> errorCivilCodeList);
@Select("<script> "+
"SELECT * FROM wvp_common_gb_channel WHERE common_gb_device_id in" +
"<foreach collection='commonGbChannelList' item='item' open='(' separator=',' close=')' > #{item.commonGbDeviceID}</foreach>" +
"</script>")
List<CommonGbChannel> queryInList(List<CommonGbChannel> commonGbChannelList);
} }

View File

@ -44,6 +44,7 @@ public interface DeviceMapper {
"on_line," + "on_line," +
"media_server_id," + "media_server_id," +
"switch_primary_sub_stream," + "switch_primary_sub_stream," +
"auto_sync_channel," +
"(SELECT count(0) FROM wvp_device_channel WHERE device_id=wvp_device.device_id) as channel_count "+ "(SELECT count(0) FROM wvp_device_channel WHERE device_id=wvp_device.device_id) as channel_count "+
" FROM wvp_device WHERE device_id = #{deviceId}") " FROM wvp_device WHERE device_id = #{deviceId}")
Device getDeviceByDeviceId(String deviceId); Device getDeviceByDeviceId(String deviceId);
@ -74,6 +75,7 @@ public interface DeviceMapper {
"subscribe_cycle_for_alarm,"+ "subscribe_cycle_for_alarm,"+
"ssrc_check,"+ "ssrc_check,"+
"as_message_channel,"+ "as_message_channel,"+
"auto_sync_channel,"+
"geo_coord_sys,"+ "geo_coord_sys,"+
"on_line"+ "on_line"+
") VALUES (" + ") VALUES (" +
@ -102,6 +104,7 @@ public interface DeviceMapper {
"#{subscribeCycleForAlarm}," + "#{subscribeCycleForAlarm}," +
"#{ssrcCheck}," + "#{ssrcCheck}," +
"#{asMessageChannel}," + "#{asMessageChannel}," +
"#{autoSyncChannel}," +
"#{geoCoordSys}," + "#{geoCoordSys}," +
"#{onLine}" + "#{onLine}" +
")") ")")
@ -160,6 +163,7 @@ public interface DeviceMapper {
"on_line,"+ "on_line,"+
"media_server_id,"+ "media_server_id,"+
"switch_primary_sub_stream switchPrimarySubStream,"+ "switch_primary_sub_stream switchPrimarySubStream,"+
"auto_sync_channel,"+
"(SELECT count(0) FROM wvp_device_channel WHERE device_id=de.device_id) as channel_count " + "(SELECT count(0) FROM wvp_device_channel WHERE device_id=de.device_id) as channel_count " +
"FROM wvp_device de" + "FROM wvp_device de" +
"<if test=\"onLine != null\"> where on_line=${onLine}</if>"+ "<if test=\"onLine != null\"> where on_line=${onLine}</if>"+
@ -197,6 +201,7 @@ public interface DeviceMapper {
"subscribe_cycle_for_alarm,"+ "subscribe_cycle_for_alarm,"+
"ssrc_check,"+ "ssrc_check,"+
"as_message_channel,"+ "as_message_channel,"+
"auto_sync_channel,"+
"geo_coord_sys,"+ "geo_coord_sys,"+
"on_line"+ "on_line"+
" FROM wvp_device WHERE on_line = true") " FROM wvp_device WHERE on_line = true")
@ -227,6 +232,7 @@ public interface DeviceMapper {
"subscribe_cycle_for_alarm,"+ "subscribe_cycle_for_alarm,"+
"ssrc_check,"+ "ssrc_check,"+
"as_message_channel,"+ "as_message_channel,"+
"auto_sync_channel,"+
"geo_coord_sys,"+ "geo_coord_sys,"+
"on_line"+ "on_line"+
" FROM wvp_device WHERE ip = #{host} AND port=#{port}") " FROM wvp_device WHERE ip = #{host} AND port=#{port}")
@ -250,6 +256,7 @@ public interface DeviceMapper {
"<if test=\"asMessageChannel != null\">, as_message_channel=#{asMessageChannel}</if>" + "<if test=\"asMessageChannel != null\">, as_message_channel=#{asMessageChannel}</if>" +
"<if test=\"geoCoordSys != null\">, geo_coord_sys=#{geoCoordSys}</if>" + "<if test=\"geoCoordSys != null\">, geo_coord_sys=#{geoCoordSys}</if>" +
"<if test=\"switchPrimarySubStream != null\">, switch_primary_sub_stream=#{switchPrimarySubStream}</if>" + "<if test=\"switchPrimarySubStream != null\">, switch_primary_sub_stream=#{switchPrimarySubStream}</if>" +
"<if test=\"autoSyncChannel != null\">, auto_sync_channel=#{autoSyncChannel}</if>" +
"<if test=\"mediaServerId != null\">, media_server_id=#{mediaServerId}</if>" + "<if test=\"mediaServerId != null\">, media_server_id=#{mediaServerId}</if>" +
"WHERE device_id=#{deviceId}"+ "WHERE device_id=#{deviceId}"+
" </script>"}) " </script>"})
@ -265,6 +272,7 @@ public interface DeviceMapper {
"charset,"+ "charset,"+
"ssrc_check,"+ "ssrc_check,"+
"as_message_channel,"+ "as_message_channel,"+
"auto_sync_channel,"+
"geo_coord_sys,"+ "geo_coord_sys,"+
"on_line,"+ "on_line,"+
"media_server_id,"+ "media_server_id,"+
@ -279,6 +287,7 @@ public interface DeviceMapper {
"#{charset}," + "#{charset}," +
"#{ssrcCheck}," + "#{ssrcCheck}," +
"#{asMessageChannel}," + "#{asMessageChannel}," +
"#{autoSyncChannel}," +
"#{geoCoordSys}," + "#{geoCoordSys}," +
"#{onLine}," + "#{onLine}," +
"#{mediaServerId}," + "#{mediaServerId}," +

View File

@ -69,15 +69,19 @@ public interface GroupMapper {
"common_group_create_time, " + "common_group_create_time, " +
"common_group_update_time " + "common_group_update_time " +
") values " + ") values " +
"<foreach collection='allGroup' index='index' item='item' separator=','> " + "<foreach collection='allGroup' index='index' item='item' separator=',' open='(' close=')'> " +
"( " +
"#{item.commonGroupDeviceId}, " + "#{item.commonGroupDeviceId}, " +
"#{item.commonGroupName}, " + "#{item.commonGroupName}, " +
"#{item.commonGroupParentId}, " + "#{item.commonGroupParentId}, " +
"#{item.commonGroupCreateTime}, " + "#{item.commonGroupCreateTime}, " +
"#{item.commonGroupUpdateTime} " + "#{item.commonGroupUpdateTime} " +
")" +
"</foreach>" + "</foreach>" +
"</script>") "</script>")
int addAll(List<Group> allGroup); int addAll(List<Group> allGroup);
@Select("<script> "+
"SELECT * FROM wvp_common_group WHERE common_group_device_id in" +
"<foreach collection='allGroup' item='item' open='(' separator=',' close=')' > #{item.commonGroupDeviceId}</foreach>" +
"</script>")
List<Group> queryInList(List<Group> allGroup);
} }