减少重复sql
parent
8ef8773db6
commit
c9d14bb23b
|
@ -3,6 +3,7 @@ package com.genersoft.iot.vmp.gb28181.dao;
|
||||||
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
||||||
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
|
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
|
||||||
import com.genersoft.iot.vmp.gb28181.controller.bean.ChannelReduce;
|
import com.genersoft.iot.vmp.gb28181.controller.bean.ChannelReduce;
|
||||||
|
import com.genersoft.iot.vmp.gb28181.dao.provider.DeviceChannelProvider;
|
||||||
import com.genersoft.iot.vmp.service.bean.GPSMsgInfo;
|
import com.genersoft.iot.vmp.service.bean.GPSMsgInfo;
|
||||||
import com.genersoft.iot.vmp.web.gb28181.dto.DeviceChannelExtend;
|
import com.genersoft.iot.vmp.web.gb28181.dto.DeviceChannelExtend;
|
||||||
import org.apache.ibatis.annotations.*;
|
import org.apache.ibatis.annotations.*;
|
||||||
|
@ -78,110 +79,7 @@ public interface DeviceChannelMapper {
|
||||||
" </script>"})
|
" </script>"})
|
||||||
int update(DeviceChannel channel);
|
int update(DeviceChannel channel);
|
||||||
|
|
||||||
@Update(value = {" <script>" +
|
@SelectProvider(type = DeviceChannelProvider.class, method = "queryChannels")
|
||||||
"UPDATE wvp_device_channel " +
|
|
||||||
"SET update_time=#{updateTime}" +
|
|
||||||
", gb_name = #{gbName}" +
|
|
||||||
", gb_manufacturer = #{gbManufacturer}" +
|
|
||||||
", gb_model = #{gbModel}" +
|
|
||||||
", gb_owner = #{gbOwner}" +
|
|
||||||
", gb_civil_code = #{gbCivilCode}" +
|
|
||||||
", gb_block = #{gbBlock}" +
|
|
||||||
", gb_address = #{gbAddress}" +
|
|
||||||
", gb_parental = #{gbParental}" +
|
|
||||||
", gb_parent_id = #{gbParentId}" +
|
|
||||||
", gb_safety_way = #{gbSafetyWay}" +
|
|
||||||
", gb_register_way = #{gbRegisterWay}" +
|
|
||||||
", gb_cert_num = #{gbCertNum}" +
|
|
||||||
", gb_certifiable = #{gbCertifiable}" +
|
|
||||||
", gb_err_code = #{gbErrCode}" +
|
|
||||||
", gb_end_time = #{gbEndTime}" +
|
|
||||||
", gb_secrecy = #{gbSecrecy}" +
|
|
||||||
", gb_ip_address = #{gbIpAddress}" +
|
|
||||||
", gb_port = #{gbPort}" +
|
|
||||||
", gb_password = #{gbPassword}" +
|
|
||||||
", gb_status = #{gbStatus}" +
|
|
||||||
", gb_longitude = #{gbLongitude}" +
|
|
||||||
", gb_latitude = #{gbLatitude}" +
|
|
||||||
", gb_ptz_type = #{gbPtzType}" +
|
|
||||||
", gb_position_type = #{gbPositionType}" +
|
|
||||||
", gb_room_type = #{gbRoomType}" +
|
|
||||||
", gb_use_type = #{gbUseType}" +
|
|
||||||
", gb_supply_light_type = #{gbSupplyLightType}" +
|
|
||||||
", gb_direction_type = #{gbDirectionType}" +
|
|
||||||
", gb_resolution = #{gbResolution}" +
|
|
||||||
", gb_business_group_id = #{gbBusinessGroupId}" +
|
|
||||||
", gb_download_speed = #{gbDownloadSpeed}" +
|
|
||||||
", gb_svc_space_support_mod = #{gbSvcSpaceSupportMod}" +
|
|
||||||
", gb_svc_time_support_mode = #{gbSvcTimeSupportMode}" +
|
|
||||||
" WHERE id = #{id}" +
|
|
||||||
" </script>"})
|
|
||||||
int updateCustomInfo(DeviceChannel channel);
|
|
||||||
|
|
||||||
@Select(value = {" <script>" +
|
|
||||||
"SELECT " +
|
|
||||||
" dc.id,\n" +
|
|
||||||
" dc.device_db_id,\n" +
|
|
||||||
" dc.create_time,\n" +
|
|
||||||
" dc.update_time,\n" +
|
|
||||||
" dc.sub_count,\n" +
|
|
||||||
" dc.stream_id,\n" +
|
|
||||||
" dc.has_audio,\n" +
|
|
||||||
" dc.gps_time,\n" +
|
|
||||||
" dc.stream_identification,\n" +
|
|
||||||
" dc.channel_type,\n" +
|
|
||||||
" coalesce(dc.gb_device_id, dc.device_id) as device_id,\n" +
|
|
||||||
" coalesce(dc.gb_name, dc.name) as name,\n" +
|
|
||||||
" coalesce(dc.gb_manufacturer, dc.manufacturer) as manufacturer,\n" +
|
|
||||||
" coalesce(dc.gb_model, dc.model) as model,\n" +
|
|
||||||
" coalesce(dc.gb_owner, dc.owner) as owner,\n" +
|
|
||||||
" coalesce(dc.gb_civil_code, dc.civil_code) as civil_code,\n" +
|
|
||||||
" coalesce(dc.gb_block, dc.block) as block,\n" +
|
|
||||||
" coalesce(dc.gb_address, dc.address) as address,\n" +
|
|
||||||
" coalesce(dc.gb_parental, dc.parental) as parental,\n" +
|
|
||||||
" coalesce(dc.gb_parent_id, dc.parent_id) as parent_id,\n" +
|
|
||||||
" coalesce(dc.gb_safety_way, dc.safety_way) as safety_way,\n" +
|
|
||||||
" coalesce(dc.gb_register_way, dc.register_way) as register_way,\n" +
|
|
||||||
" coalesce(dc.gb_cert_num, dc.cert_num) as cert_num,\n" +
|
|
||||||
" coalesce(dc.gb_certifiable, dc.certifiable) as certifiable,\n" +
|
|
||||||
" coalesce(dc.gb_err_code, dc.err_code) as err_code,\n" +
|
|
||||||
" coalesce(dc.gb_end_time, dc.end_time) as end_time,\n" +
|
|
||||||
" coalesce(dc.gb_secrecy, dc.secrecy) as secrecy,\n" +
|
|
||||||
" coalesce(dc.gb_ip_address, dc.ip_address) as ip_address,\n" +
|
|
||||||
" coalesce(dc.gb_port, dc.port) as port,\n" +
|
|
||||||
" coalesce(dc.gb_password, dc.password) as password,\n" +
|
|
||||||
" coalesce(dc.gb_status, dc.status) as status,\n" +
|
|
||||||
" coalesce(dc.gb_longitude, dc.longitude) as longitude,\n" +
|
|
||||||
" coalesce(dc.gb_latitude, dc.latitude) as latitude,\n" +
|
|
||||||
" coalesce(dc.gb_ptz_type, dc.ptz_type) as ptz_type,\n" +
|
|
||||||
" coalesce(dc.gb_position_type, dc.position_type) as position_type,\n" +
|
|
||||||
" coalesce(dc.gb_room_type, dc.room_type) as room_type,\n" +
|
|
||||||
" coalesce(dc.gb_use_type, dc.use_type) as use_type,\n" +
|
|
||||||
" coalesce(dc.gb_supply_light_type, dc.supply_light_type) as supply_light_type,\n" +
|
|
||||||
" coalesce(dc.gb_direction_type, dc.direction_type) as direction_type,\n" +
|
|
||||||
" coalesce(dc.gb_resolution, dc.resolution) as resolution,\n" +
|
|
||||||
" coalesce(dc.gb_business_group_id, dc.business_group_id) as business_group_id,\n" +
|
|
||||||
" coalesce(dc.gb_download_speed, dc.download_speed) as download_speed,\n" +
|
|
||||||
" coalesce(dc.gb_svc_space_support_mod, dc.svc_space_support_mod) as svc_space_support_mod,\n" +
|
|
||||||
" coalesce(dc.gb_svc_time_support_mode,dc.svc_time_support_mode) as svc_time_support_mode\n" +
|
|
||||||
" from " +
|
|
||||||
" wvp_device_channel dc " +
|
|
||||||
" WHERE " +
|
|
||||||
" dc.device_db_id = #{deviceDbId} " +
|
|
||||||
" <if test='query != null'> AND (" +
|
|
||||||
"coalesce(dc.gb_device_id, dc.device_id) LIKE concat('%',#{query},'%') " +
|
|
||||||
"OR coalesce(dc.gb_name, dc.name) LIKE concat('%',#{query},'%') " +
|
|
||||||
")</if> " +
|
|
||||||
" <if test='parentChannelId != null'> AND (dc.parent_id=#{parentChannelId} OR coalesce(dc.gb_civil_code, dc.civil_code) = #{parentChannelId}) </if> " +
|
|
||||||
" <if test='online == true' > AND dc.status= 'ON'</if>" +
|
|
||||||
" <if test='online == false' > AND dc.status= 'OFF'</if>" +
|
|
||||||
" <if test='hasSubChannel == true' > AND dc.sub_count > 0 </if>" +
|
|
||||||
" <if test='hasSubChannel == false' > AND dc.sub_count = 0 </if>" +
|
|
||||||
"<if test='channelIds != null'> AND dc.device_id in <foreach item='item' index='index' collection='channelIds' open='(' separator=',' close=')'>" +
|
|
||||||
"#{item} " +
|
|
||||||
"</foreach> </if>" +
|
|
||||||
"ORDER BY dc.device_id " +
|
|
||||||
" </script>"})
|
|
||||||
List<DeviceChannel> queryChannels(@Param("deviceDbId") int deviceDbId, @Param("parentChannelId") String parentChannelId, @Param("query") String query, @Param("hasSubChannel") Boolean hasSubChannel, @Param("online") Boolean online, @Param("channelIds") List<String> channelIds);
|
List<DeviceChannel> queryChannels(@Param("deviceDbId") int deviceDbId, @Param("parentChannelId") String parentChannelId, @Param("query") String query, @Param("hasSubChannel") Boolean hasSubChannel, @Param("online") Boolean online, @Param("channelIds") List<String> channelIds);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,312 @@
|
||||||
|
package com.genersoft.iot.vmp.gb28181.dao.provider;
|
||||||
|
|
||||||
|
import com.genersoft.iot.vmp.gb28181.bean.CommonGBChannel;
|
||||||
|
import com.genersoft.iot.vmp.gb28181.bean.Group;
|
||||||
|
import com.genersoft.iot.vmp.streamPush.bean.StreamPush;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class DeviceChannelProvider {
|
||||||
|
|
||||||
|
public String getBaseSelectSql(){
|
||||||
|
return "SELECT " +
|
||||||
|
" dc.id,\n" +
|
||||||
|
" dc.device_db_id,\n" +
|
||||||
|
" dc.create_time,\n" +
|
||||||
|
" dc.update_time,\n" +
|
||||||
|
" dc.sub_count,\n" +
|
||||||
|
" dc.stream_id,\n" +
|
||||||
|
" dc.has_audio,\n" +
|
||||||
|
" dc.gps_time,\n" +
|
||||||
|
" dc.stream_identification,\n" +
|
||||||
|
" dc.channel_type,\n" +
|
||||||
|
" coalesce(dc.gb_device_id, dc.device_id) as device_id,\n" +
|
||||||
|
" coalesce(dc.gb_name, dc.name) as name,\n" +
|
||||||
|
" coalesce(dc.gb_manufacturer, dc.manufacturer) as manufacturer,\n" +
|
||||||
|
" coalesce(dc.gb_model, dc.model) as model,\n" +
|
||||||
|
" coalesce(dc.gb_owner, dc.owner) as owner,\n" +
|
||||||
|
" coalesce(dc.gb_civil_code, dc.civil_code) as civil_code,\n" +
|
||||||
|
" coalesce(dc.gb_block, dc.block) as block,\n" +
|
||||||
|
" coalesce(dc.gb_address, dc.address) as address,\n" +
|
||||||
|
" coalesce(dc.gb_parental, dc.parental) as parental,\n" +
|
||||||
|
" coalesce(dc.gb_parent_id, dc.parent_id) as parent_id,\n" +
|
||||||
|
" coalesce(dc.gb_safety_way, dc.safety_way) as safety_way,\n" +
|
||||||
|
" coalesce(dc.gb_register_way, dc.register_way) as register_way,\n" +
|
||||||
|
" coalesce(dc.gb_cert_num, dc.cert_num) as cert_num,\n" +
|
||||||
|
" coalesce(dc.gb_certifiable, dc.certifiable) as certifiable,\n" +
|
||||||
|
" coalesce(dc.gb_err_code, dc.err_code) as err_code,\n" +
|
||||||
|
" coalesce(dc.gb_end_time, dc.end_time) as end_time,\n" +
|
||||||
|
" coalesce(dc.gb_secrecy, dc.secrecy) as secrecy,\n" +
|
||||||
|
" coalesce(dc.gb_ip_address, dc.ip_address) as ip_address,\n" +
|
||||||
|
" coalesce(dc.gb_port, dc.port) as port,\n" +
|
||||||
|
" coalesce(dc.gb_password, dc.password) as password,\n" +
|
||||||
|
" coalesce(dc.gb_status, dc.status) as status,\n" +
|
||||||
|
" coalesce(dc.gb_longitude, dc.longitude) as longitude,\n" +
|
||||||
|
" coalesce(dc.gb_latitude, dc.latitude) as latitude,\n" +
|
||||||
|
" coalesce(dc.gb_ptz_type, dc.ptz_type) as ptz_type,\n" +
|
||||||
|
" coalesce(dc.gb_position_type, dc.position_type) as position_type,\n" +
|
||||||
|
" coalesce(dc.gb_room_type, dc.room_type) as room_type,\n" +
|
||||||
|
" coalesce(dc.gb_use_type, dc.use_type) as use_type,\n" +
|
||||||
|
" coalesce(dc.gb_supply_light_type, dc.supply_light_type) as supply_light_type,\n" +
|
||||||
|
" coalesce(dc.gb_direction_type, dc.direction_type) as direction_type,\n" +
|
||||||
|
" coalesce(dc.gb_resolution, dc.resolution) as resolution,\n" +
|
||||||
|
" coalesce(dc.gb_business_group_id, dc.business_group_id) as business_group_id,\n" +
|
||||||
|
" coalesce(dc.gb_download_speed, dc.download_speed) as download_speed,\n" +
|
||||||
|
" coalesce(dc.gb_svc_space_support_mod, dc.svc_space_support_mod) as svc_space_support_mod,\n" +
|
||||||
|
" coalesce(dc.gb_svc_time_support_mode,dc.svc_time_support_mode) as svc_time_support_mode\n" +
|
||||||
|
" from " +
|
||||||
|
" wvp_device_channel dc "
|
||||||
|
;
|
||||||
|
}
|
||||||
|
public String queryChannels(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append(" where 1=1");
|
||||||
|
if (params.get("query") != null) {
|
||||||
|
sqlBuild.append(" AND coalesce(dc.gb_device_id, dc.device_id) LIKE concat('%',#{query},'%')" +
|
||||||
|
" OR coalesce(dc.gb_name, dc.name) LIKE concat('%',#{query},'%')")
|
||||||
|
;
|
||||||
|
}
|
||||||
|
if (params.get("parentChannelId") != null ) {
|
||||||
|
sqlBuild.append(" AND (dc.parent_id=#{parentChannelId} OR coalesce(dc.gb_civil_code, dc.civil_code) = #{parentChannelId})");
|
||||||
|
}
|
||||||
|
if (params.get("online") != null && (Boolean)params.get("online")) {
|
||||||
|
sqlBuild.append(" AND coalesce(gb_status, status) = 'ON'");
|
||||||
|
}
|
||||||
|
if (params.get("online") != null && !(Boolean)params.get("online")) {
|
||||||
|
sqlBuild.append(" AND coalesce(gb_status, status) = 'OFF'");
|
||||||
|
}
|
||||||
|
if (params.get("hasSubChannel") != null && (Boolean)params.get("hasSubChannel")) {
|
||||||
|
sqlBuild.append(" AND dc.sub_count > 0");
|
||||||
|
}
|
||||||
|
if (params.get("hasSubChannel") != null && !(Boolean)params.get("hasSubChannel")) {
|
||||||
|
sqlBuild.append(" AND dc.sub_count = 0");
|
||||||
|
}
|
||||||
|
List<String> channelIds = (List<String>)params.get("channelIds");
|
||||||
|
if (channelIds != null && !channelIds.isEmpty()) {
|
||||||
|
sqlBuild.append(" AND dc.device_id in (");
|
||||||
|
boolean first = true;
|
||||||
|
for (String id : channelIds) {
|
||||||
|
if (!first) {
|
||||||
|
sqlBuild.append(",");
|
||||||
|
}
|
||||||
|
sqlBuild.append(id);
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
sqlBuild.append(" )");
|
||||||
|
}
|
||||||
|
return sqlBuild.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public String queryByDeviceId(Map<String, Object> params ){
|
||||||
|
return getBaseSelectSql() + " where channel_type = 0 and coalesce(gb_device_id, device_id) = #{gbDeviceId}";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryById(Map<String, Object> params ){
|
||||||
|
return getBaseSelectSql() + " where channel_type = 0 and id = #{gbId}";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByStreamPushId(Map<String, Object> params ){
|
||||||
|
return getBaseSelectSql() + " where channel_type = 0 and stream_push_id = #{streamPushId}";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByStreamProxyId(Map<String, Object> params ){
|
||||||
|
return getBaseSelectSql() + " where channel_type = 0 and stream_proxy_id = #{streamProxyId}";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public String queryList(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append(" where channel_type = 0 ");
|
||||||
|
if (params.get("query") != null) {
|
||||||
|
sqlBuild.append(" AND (coalesce(gb_device_id, device_id) LIKE concat('%',#{query},'%')" +
|
||||||
|
" OR coalesce(gb_name, name) LIKE concat('%',#{query},'%') )")
|
||||||
|
;
|
||||||
|
}
|
||||||
|
if (params.get("online") != null && (Boolean)params.get("online")) {
|
||||||
|
sqlBuild.append(" AND coalesce(gb_status, status) = 'ON'");
|
||||||
|
}
|
||||||
|
if (params.get("online") != null && !(Boolean)params.get("online")) {
|
||||||
|
sqlBuild.append(" AND coalesce(gb_status, status) = 'OFF'");
|
||||||
|
}
|
||||||
|
if (params.get("hasCivilCode") != null && (Boolean)params.get("hasCivilCode")) {
|
||||||
|
sqlBuild.append(" AND coalesce(gb_civil_code, civil_code) is not null");
|
||||||
|
}
|
||||||
|
if (params.get("hasCivilCode") != null && !(Boolean)params.get("hasCivilCode")) {
|
||||||
|
sqlBuild.append(" AND coalesce(gb_civil_code, civil_code) is null");
|
||||||
|
}
|
||||||
|
if (params.get("hasGroup") != null && (Boolean)params.get("hasGroup")) {
|
||||||
|
sqlBuild.append(" AND coalesce(gb_parent_id, parent_id) is not null");
|
||||||
|
}
|
||||||
|
if (params.get("hasGroup") != null && !(Boolean)params.get("hasGroup")) {
|
||||||
|
sqlBuild.append(" AND coalesce(gb_parent_id, parent_id) is null");
|
||||||
|
}
|
||||||
|
return sqlBuild.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public String queryInListByStatus(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append("where channel_type = 0 and gb_status=#{status} and id in ( ");
|
||||||
|
|
||||||
|
List<CommonGBChannel> commonGBChannelList = (List<CommonGBChannel>)params.get("commonGBChannelList");
|
||||||
|
boolean first = true;
|
||||||
|
for (CommonGBChannel channel : commonGBChannelList) {
|
||||||
|
if (!first) {
|
||||||
|
sqlBuild.append(",");
|
||||||
|
}
|
||||||
|
sqlBuild.append(channel.getGbId());
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
sqlBuild.append(" )");
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByIds(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append("where channel_type = 0 and id in ( ");
|
||||||
|
|
||||||
|
Collection<Integer> ids = (Collection<Integer>)params.get("ids");
|
||||||
|
boolean first = true;
|
||||||
|
for (Integer id : ids) {
|
||||||
|
if (!first) {
|
||||||
|
sqlBuild.append(",");
|
||||||
|
}
|
||||||
|
sqlBuild.append(id);
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
sqlBuild.append(" )");
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByGbDeviceIds(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append("where channel_type = 0 and device_db_id in ( ");
|
||||||
|
|
||||||
|
Collection<Integer> ids = (Collection<Integer>)params.get("deviceIds");
|
||||||
|
boolean first = true;
|
||||||
|
for (Integer id : ids) {
|
||||||
|
if (!first) {
|
||||||
|
sqlBuild.append(",");
|
||||||
|
}
|
||||||
|
sqlBuild.append(id);
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
sqlBuild.append(" )");
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByDeviceIds(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append("where channel_type = 0 and id in ( ");
|
||||||
|
|
||||||
|
Collection<Integer> ids = (Collection<Integer>)params.get("deviceIds");
|
||||||
|
boolean first = true;
|
||||||
|
for (Integer id : ids) {
|
||||||
|
if (!first) {
|
||||||
|
sqlBuild.append(",");
|
||||||
|
}
|
||||||
|
sqlBuild.append(id);
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
sqlBuild.append(" )");
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByIdsOrCivilCode(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append("where channel_type = 0 and ");
|
||||||
|
if (params.get("civilCode") != null) {
|
||||||
|
sqlBuild.append(" coalesce(gb_civil_code, civil_code) = #{civilCode} ");
|
||||||
|
if (params.get("ids") != null) {
|
||||||
|
sqlBuild.append(" OR ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (params.get("ids") != null) {
|
||||||
|
sqlBuild.append(" id in ( ");
|
||||||
|
Collection<Integer> ids = (Collection<Integer>)params.get("ids");
|
||||||
|
boolean first = true;
|
||||||
|
for (Integer id : ids) {
|
||||||
|
if (!first) {
|
||||||
|
sqlBuild.append(",");
|
||||||
|
}
|
||||||
|
sqlBuild.append(id);
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
sqlBuild.append(" )");
|
||||||
|
}
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByCivilCode(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append("where channel_type = 0 and coalesce(gb_civil_code, civil_code) = #{civilCode} ");
|
||||||
|
return sqlBuild.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByBusinessGroup(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append("where channel_type = 0 and coalesce(gb_business_group_id, business_group_id) = #{businessGroup} ");
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByParentId(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
sqlBuild.append("where channel_type = 0 and gb_parent_id = #{parentId} ");
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryByGroupList(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
|
||||||
|
sqlBuild.append(" where channel_type = 0 and gb_parent_id in ( ");
|
||||||
|
Collection<Group> ids = (Collection<Group>)params.get("groupList");
|
||||||
|
boolean first = true;
|
||||||
|
for (Group group : ids) {
|
||||||
|
if (!first) {
|
||||||
|
sqlBuild.append(",");
|
||||||
|
}
|
||||||
|
sqlBuild.append(group.getDeviceId());
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
sqlBuild.append(" )");
|
||||||
|
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String queryListByStreamPushList(Map<String, Object> params ){
|
||||||
|
StringBuilder sqlBuild = new StringBuilder();
|
||||||
|
sqlBuild.append(getBaseSelectSql());
|
||||||
|
|
||||||
|
sqlBuild.append(" where channel_type = 0 and stream_push_id in ( ");
|
||||||
|
Collection<StreamPush> ids = (Collection<StreamPush>)params.get("streamPushList");
|
||||||
|
boolean first = true;
|
||||||
|
for (StreamPush streamPush : ids) {
|
||||||
|
if (!first) {
|
||||||
|
sqlBuild.append(",");
|
||||||
|
}
|
||||||
|
sqlBuild.append(streamPush.getId());
|
||||||
|
first = false;
|
||||||
|
}
|
||||||
|
sqlBuild.append(" )");
|
||||||
|
|
||||||
|
return sqlBuild.toString() ;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue