1.修改按DI更新逻辑

zhairh
x_z 2 years ago
parent a0c9a75cda
commit 7c98851352

@ -3,15 +3,12 @@ package com.glxp.udidl.admin.config;
import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor; import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.datatype.jdk8.Jdk8Module;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
import com.fasterxml.jackson.module.paramnames.ParameterNamesModule;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory; import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.core.*;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer; import org.springframework.data.redis.serializer.StringRedisSerializer;
/** /**
* Redis * Redis
@ -20,24 +17,86 @@ import org.springframework.data.redis.serializer.RedisSerializer;
public class RedisConfig { public class RedisConfig {
@Bean @Bean
public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory cf) { public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory factory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>(); RedisTemplate<String, Object> template = new RedisTemplate<>();
redisTemplate.setConnectionFactory(cf); // 配置连接工厂
redisTemplate.setValueSerializer(RedisSerializer.json()); template.setConnectionFactory(factory);
redisTemplate.setHashValueSerializer(RedisSerializer.string());
redisTemplate.setKeySerializer(RedisSerializer.string()); //使用Jackson2JsonRedisSerializer来序列化和反序列化redis的value值默认使用JDK的序列化方式
redisTemplate.setHashKeySerializer(RedisSerializer.string()); Jackson2JsonRedisSerializer jsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
redisTemplate.afterPropertiesSet();
Jackson2JsonRedisSerializer<Object> serializer = new Jackson2JsonRedisSerializer<>(Object.class); ObjectMapper om = new ObjectMapper();
ObjectMapper objectMapper = new ObjectMapper() // 指定要序列化的域field,get和set,以及修饰符范围ANY是都有包括private和public
.registerModule(new ParameterNamesModule()) om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
.registerModule(new Jdk8Module()) // 指定序列化输入的类型类必须是非final修饰的final修饰的类比如String,Integer等会跑出异常
.registerModule(new JavaTimeModule()); om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); jsonRedisSerializer.setObjectMapper(om);
objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
serializer.setObjectMapper(objectMapper); // 值采用json序列化
redisTemplate.setValueSerializer(serializer); template.setValueSerializer(jsonRedisSerializer);
return redisTemplate; //使用StringRedisSerializer来序列化和反序列化redis的key值
template.setKeySerializer(new StringRedisSerializer());
// 设置hash key 和value序列化模式
template.setHashKeySerializer(new StringRedisSerializer());
template.setHashValueSerializer(jsonRedisSerializer);
template.afterPropertiesSet();
return template;
}
/**
* hash
*
* @param redisTemplate
* @return
*/
@Bean
public HashOperations<String, String, Object> hashOperations(RedisTemplate<String, Object> redisTemplate) {
return redisTemplate.opsForHash();
}
/**
* redis
*
* @param redisTemplate
* @return
*/
@Bean
public ValueOperations<String, Object> valueOperations(RedisTemplate<String, Object> redisTemplate) {
return redisTemplate.opsForValue();
}
/**
*
*
* @param redisTemplate
* @return
*/
@Bean
public ListOperations<String, Object> listOperations(RedisTemplate<String, Object> redisTemplate) {
return redisTemplate.opsForList();
}
/**
*
*
* @param redisTemplate
* @return
*/
@Bean
public SetOperations<String, Object> setOperations(RedisTemplate<String, Object> redisTemplate) {
return redisTemplate.opsForSet();
}
/**
*
*
* @param redisTemplate
* @return
*/
@Bean
public ZSetOperations<String, Object> zSetOperations(RedisTemplate<String, Object> redisTemplate) {
return redisTemplate.opsForZSet();
} }
} }

@ -56,4 +56,6 @@ public interface ProductInfoMapper extends BaseMapper<ProductInfoEntity> {
List<ProductDetailModel> selectByDeviceRecordKey(String key); List<ProductDetailModel> selectByDeviceRecordKey(String key);
boolean updateCplx(ProductInfoEntity productInfoEntity); boolean updateCplx(ProductInfoEntity productInfoEntity);
boolean updateProductInfoData(ProductInfoEntity productInfoEntity);
} }

@ -1,15 +1,16 @@
package com.glxp.udidl.admin.entity.udi; package com.glxp.udidl.admin.entity.udi;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty; import io.swagger.annotations.ApiModelProperty;
import lombok.Data; import lombok.Data;
import springfox.documentation.annotations.ApiIgnore;
import java.util.Date; import java.util.Date;
@Data @Data
@ApiModel(value = "产品信息实体") @ApiModel(value = "产品信息实体")
@TableName("productinfo")
public class ProductInfoEntity { public class ProductInfoEntity {
@ApiModelProperty(value = "主键ID") @ApiModelProperty(value = "主键ID")

@ -10,7 +10,6 @@ import java.util.Date;
@Data @Data
public class Device { public class Device {
@ApiModelProperty(value = "同一产品同一版本号唯一主键") @ApiModelProperty(value = "同一产品同一版本号唯一主键")
private String uuid; private String uuid;

@ -1,6 +1,9 @@
package com.glxp.udidl.admin.service.dataUpdate; package com.glxp.udidl.admin.service.dataUpdate;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.glxp.udidl.admin.dao.udi.ProductInfoMapper;
import com.glxp.udidl.admin.dao.udid.DeviceMapper;
import com.glxp.udidl.admin.entity.udi.CountProductEntity; import com.glxp.udidl.admin.entity.udi.CountProductEntity;
import com.glxp.udidl.admin.entity.udi.ProductClassify; import com.glxp.udidl.admin.entity.udi.ProductClassify;
import com.glxp.udidl.admin.entity.udi.ProductInfoEntity; import com.glxp.udidl.admin.entity.udi.ProductInfoEntity;
@ -30,11 +33,15 @@ public class DeviceParseService {
@Resource @Resource
private DeviceService deviceService; private DeviceService deviceService;
@Resource @Resource
ProductClassifyService productClassifyService; private ProductClassifyService productClassifyService;
@Resource @Resource
ProductInfoService productInfoService; private ProductInfoService productInfoService;
@Resource @Resource
UdiCompanyService udiCompanyService; private UdiCompanyService udiCompanyService;
@Resource
private DeviceMapper deviceMapper;
@Resource
private ProductInfoMapper productInfoMapper;
/** /**
* *
@ -50,11 +57,13 @@ public class DeviceParseService {
List<DataSetResult.PackingInfo> packingInfoAll = ds.getPackingInfo(); List<DataSetResult.PackingInfo> packingInfoAll = ds.getPackingInfo();
for (DataSetResult.DeviceInfo item : ds.getDeviceInfo()) { for (DataSetResult.DeviceInfo item : ds.getDeviceInfo()) {
//1:判断数据是否存在 //1:判断数据是否存在,直接以当前拉取到的最新数据进行更新
if (StrUtil.isNotEmpty(deviceService.selectDiIsSame(item.getZxxsdycpbs(), item.getVersionNumber() + ""))) String uuid = deviceService.selectDiIsSame(item.getZxxsdycpbs(), item.getVersionNumber() + "");
continue; //此版本数据存在使用当前数据库存在的数据的ID进行更新
Device device = responseToDevice(item); Device device = responseToDevice(item);
String uuid = getUUId(); if (StrUtil.isBlank(uuid)) {
uuid = getUUId();
}
Boolean isHistory = false; Boolean isHistory = false;
if (item.getDeviceHistoryKey() != null && !item.getDeviceHistoryKey().isEmpty()) { if (item.getDeviceHistoryKey() != null && !item.getDeviceHistoryKey().isEmpty()) {
isHistory = true; isHistory = true;
@ -148,7 +157,6 @@ public class DeviceParseService {
} }
deviceService.updateDevicepackage(devicepackageList); deviceService.updateDevicepackage(devicepackageList);
} }
} }
//7存储productInfo信息 //7存储productInfo信息
@ -280,7 +288,12 @@ public class DeviceParseService {
public void transUdi(String key) { public void transUdi(String key) {
DeviceEntity deviceEntity = deviceService.searchById(key); DeviceEntity deviceEntity = deviceService.searchById(key);
String di = deviceEntity.getZxxsdycpbs(); String di = deviceEntity.getZxxsdycpbs();
//查询产品表的数据ID
ProductInfoEntity oldData = productInfoMapper.selectOne(new QueryWrapper<ProductInfoEntity>().select("id").eq("uuid", key).eq("nameCode", deviceEntity.getZxxsdycpbs()));
ProductInfoEntity productInfoEntity = new ProductInfoEntity(); ProductInfoEntity productInfoEntity = new ProductInfoEntity();
if (null != oldData) {
productInfoEntity.setId(oldData.getId());
}
org.springframework.beans.BeanUtils.copyProperties(deviceEntity, productInfoEntity); org.springframework.beans.BeanUtils.copyProperties(deviceEntity, productInfoEntity);
productInfoEntity.setUuid(key); productInfoEntity.setUuid(key);
productInfoEntity.setDeviceRecordKey(deviceEntity.getDevicerecordkey()); productInfoEntity.setDeviceRecordKey(deviceEntity.getDevicerecordkey());
@ -355,7 +368,7 @@ public class DeviceParseService {
productInfoEntity.setNameCode(deviceEntity.getSydycpbs()); productInfoEntity.setNameCode(deviceEntity.getSydycpbs());
productInfoEntity.setSjcpbm(deviceEntity.getZxxsdycpbs()); productInfoEntity.setSjcpbm(deviceEntity.getZxxsdycpbs());
productInfoEntity.setUpdateTime(new Date()); productInfoEntity.setUpdateTime(new Date());
productInfoService.insertProductInfo(productInfoEntity); productInfoService.updateProductInfoData(productInfoEntity);
productInfoEntity.setBhxjcpbm(deviceEntity.getSydycpbs()); productInfoEntity.setBhxjcpbm(deviceEntity.getSydycpbs());
productInfoEntity.setBhxjsl(1); productInfoEntity.setBhxjsl(1);
productInfoEntity.setPackLevel(2 + ""); productInfoEntity.setPackLevel(2 + "");
@ -373,7 +386,7 @@ public class DeviceParseService {
productInfoEntity.setSjcpbm(deviceEntity.getZxxsdycpbs()); productInfoEntity.setSjcpbm(deviceEntity.getZxxsdycpbs());
productInfoEntity.setNameCode(deviceEntity.getBtcpbs()); productInfoEntity.setNameCode(deviceEntity.getBtcpbs());
productInfoEntity.setUpdateTime(new Date()); productInfoEntity.setUpdateTime(new Date());
productInfoService.insertProductInfo(productInfoEntity); productInfoService.updateProductInfoData(productInfoEntity);
productInfoEntity.setBhxjcpbm(deviceEntity.getBtcpbs()); productInfoEntity.setBhxjcpbm(deviceEntity.getBtcpbs());
productInfoEntity.setBhxjsl(1); productInfoEntity.setBhxjsl(1);
productInfoEntity.setPackLevel(2 + ""); productInfoEntity.setPackLevel(2 + "");
@ -391,7 +404,7 @@ public class DeviceParseService {
List<Devicepackage> devicepackages = deviceEntity.getDevicepackages(); List<Devicepackage> devicepackages = deviceEntity.getDevicepackages();
productInfoEntity.setSjcpbm(getSjcpbm(devicepackages, productInfoEntity.getNameCode())); productInfoEntity.setSjcpbm(getSjcpbm(devicepackages, productInfoEntity.getNameCode()));
productInfoEntity.setUpdateTime(new Date()); productInfoEntity.setUpdateTime(new Date());
productInfoService.insertProductInfo(productInfoEntity); productInfoService.updateProductInfoData(productInfoEntity);
List<CountProductEntity> countProductEntities = new ArrayList<>(); List<CountProductEntity> countProductEntities = new ArrayList<>();
int curLevel = Integer.parseInt(productInfoEntity.getPackLevel()) + 1; int curLevel = Integer.parseInt(productInfoEntity.getPackLevel()) + 1;
@ -436,7 +449,7 @@ public class DeviceParseService {
productInfoEntity.setSjcpbm(getSjcpbm(devicepackages, productInfoEntity.getNameCode())); productInfoEntity.setSjcpbm(getSjcpbm(devicepackages, productInfoEntity.getNameCode()));
productInfoEntity.setDiType(4); productInfoEntity.setDiType(4);
productInfoEntity.setUpdateTime(new Date()); productInfoEntity.setUpdateTime(new Date());
productInfoService.insertProductInfo(productInfoEntity); productInfoService.updateProductInfoData(productInfoEntity);
} }
} }
@ -461,7 +474,7 @@ public class DeviceParseService {
for (ProductInfoEntity change : temps) { for (ProductInfoEntity change : temps) {
change.setIsNewest(false); change.setIsNewest(false);
change.setUpdateTime(new Date()); change.setUpdateTime(new Date());
productInfoService.updateProductInfo(change); productInfoService.updateProductInfoData(change);
} }
} }

@ -13,6 +13,7 @@ import com.glxp.udidl.admin.entity.udid.TokenEntity;
import com.glxp.udidl.admin.req.UpdateUdiRequest; import com.glxp.udidl.admin.req.UpdateUdiRequest;
import com.glxp.udidl.admin.req.udid.DownloadDiRequest; import com.glxp.udidl.admin.req.udid.DownloadDiRequest;
import com.glxp.udidl.admin.req.udid.TokenRequest; import com.glxp.udidl.admin.req.udid.TokenRequest;
import com.glxp.udidl.admin.res.udid.DataSetResult;
import com.glxp.udidl.admin.res.udid.DataSetSingleResult; import com.glxp.udidl.admin.res.udid.DataSetSingleResult;
import com.glxp.udidl.admin.service.info.CompanyService; import com.glxp.udidl.admin.service.info.CompanyService;
import com.glxp.udidl.admin.service.inout.DeviceService; import com.glxp.udidl.admin.service.inout.DeviceService;
@ -83,7 +84,8 @@ public class DeviceUpdateService {
jobLog.setInsertCount(0); jobLog.setInsertCount(0);
} else { } else {
log.info("下载成功,开始更新数据"); log.info("下载成功,开始更新数据");
deviceParseService.DeviceSave(Collections.singletonList(dataSetSingleResult.getDataSet()), new Date()); DataSetResult.DataSet dataSet = dataSetSingleResult.getDataSet();
deviceParseService.DeviceSave(Collections.singletonList(dataSet), new Date());
jobLog.setInsertCount(1); jobLog.setInsertCount(1);
} }
} }
@ -100,7 +102,7 @@ public class DeviceUpdateService {
*/ */
public String getToken() { public String getToken() {
token = redisUtil.get("UDI_UPDATE_TOKEN"); token = redisUtil.get("UDI_UPDATE_TOKEN");
if (StrUtil.isEmpty(token)) { if (StrUtil.isBlank(token)) {
//查询下载数据使用的appid //查询下载数据使用的appid
CompanyEntity companyEntity = companyService.findByTaskType(Constant.TASK_TYPE_UPDATE); CompanyEntity companyEntity = companyService.findByTaskType(Constant.TASK_TYPE_UPDATE);
TokenRequest tokenRequest = new TokenRequest(); TokenRequest tokenRequest = new TokenRequest();

@ -50,4 +50,7 @@ public interface ProductInfoService {
boolean updateProductInfo(ProductInfoEntity productInfoEntity); boolean updateProductInfo(ProductInfoEntity productInfoEntity);
boolean updateCplx(ProductInfoEntity productInfoEntity); boolean updateCplx(ProductInfoEntity productInfoEntity);
boolean updateProductInfoData(ProductInfoEntity productInfoEntity);
} }

@ -16,6 +16,7 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@Transactional(rollbackFor = Exception.class)
@Service @Service
public class ProductInfoServiceImpl implements ProductInfoService { public class ProductInfoServiceImpl implements ProductInfoService {
@ -183,13 +184,11 @@ public class ProductInfoServiceImpl implements ProductInfoService {
return productInfoDao.selectByUpdateTime(startDate, endDate); return productInfoDao.selectByUpdateTime(startDate, endDate);
} }
@Transactional(rollbackFor = Exception.class)
@Override @Override
public boolean insertProductInfo(ProductInfoEntity productInfoEntity) { public boolean insertProductInfo(ProductInfoEntity productInfoEntity) {
return productInfoDao.insertProductInfo(productInfoEntity); return productInfoDao.insertProductInfo(productInfoEntity);
} }
@Transactional(rollbackFor = Exception.class)
@Override @Override
public boolean updateProductByUuid(ProductInfoEntity productInfoEntity) { public boolean updateProductByUuid(ProductInfoEntity productInfoEntity) {
return productInfoDao.updateProductByUuid(productInfoEntity); return productInfoDao.updateProductByUuid(productInfoEntity);
@ -201,19 +200,22 @@ public class ProductInfoServiceImpl implements ProductInfoService {
return productInfoDao.updateProductInfo(productInfoEntity); return productInfoDao.updateProductInfo(productInfoEntity);
} }
@Transactional(rollbackFor = Exception.class)
@Override @Override
public boolean updateCplx(ProductInfoEntity productInfoEntity) { public boolean updateCplx(ProductInfoEntity productInfoEntity) {
return productInfoDao.updateCplx(productInfoEntity); return productInfoDao.updateCplx(productInfoEntity);
} }
@Transactional(rollbackFor = Exception.class) @Override
public boolean updateProductInfoData(ProductInfoEntity productInfoEntity) {
return productInfoDao.updateProductInfoData(productInfoEntity);
}
@Override @Override
public boolean deleteById(String id) { public boolean deleteById(String id) {
return productInfoDao.deleteById(id); return productInfoDao.deleteById(id);
} }
@Transactional(rollbackFor = Exception.class)
@Override @Override
public boolean deleteAll(List<String> ids) { public boolean deleteAll(List<String> ids) {
return productInfoDao.deleteAll(ids); return productInfoDao.deleteAll(ids);

@ -3,10 +3,12 @@ package com.glxp.udidl.admin.util;
import cn.hutool.core.collection.CollUtil; import cn.hutool.core.collection.CollUtil;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.util.Set; import java.util.Set;
import java.util.concurrent.TimeUnit;
/** /**
* redis * redis
@ -25,7 +27,8 @@ public class RedisUtil<T> {
* @return * @return
*/ */
public String get(String key) { public String get(String key) {
return String.valueOf(redisTemplate.opsForValue().get(key)); redisTemplate.setValueSerializer(new StringRedisSerializer());
return key == null ? null : (String) redisTemplate.opsForValue().get(key);
} }
/** /**
@ -49,7 +52,11 @@ public class RedisUtil<T> {
public boolean setEx(String key, String value, long expireTime) { public boolean setEx(String key, String value, long expireTime) {
boolean result = false; boolean result = false;
try { try {
redisTemplate.opsForValue().set(key, value, expireTime); if (expireTime > 0) {
redisTemplate.opsForValue().set(key, value, expireTime, TimeUnit.SECONDS);
} else {
set(key, value);
}
result = true; result = true;
} catch (Exception e) { } catch (Exception e) {
log.error("RedisUtil setEx 发生异常参数列表key {} value {}", key, value, e); log.error("RedisUtil setEx 发生异常参数列表key {} value {}", key, value, e);
@ -84,7 +91,7 @@ public class RedisUtil<T> {
* @param value * @param value
* @return * @return
*/ */
public boolean set(String key, T value) { public boolean set(String key, Object value) {
boolean result = false; boolean result = false;
try { try {
redisTemplate.opsForValue().set(key, value); redisTemplate.opsForValue().set(key, value);

@ -28,7 +28,7 @@ ssl = false;
#----- 自定义分组的连接 #----- 自定义分组的连接
[custom] [custom]
# 地址默认localhost # 地址默认localhost
host = 127.0.0.1 host = 192.168.235.137
# 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true # 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true
BlockWhenExhausted = true; BlockWhenExhausted = true;
# 设置的逐出策略类名, 默认DefaultEvictionPolicy(当连接超过最大空闲时间,或连接数超过最大空闲连接数) # 设置的逐出策略类名, 默认DefaultEvictionPolicy(当连接超过最大空闲时间,或连接数超过最大空闲连接数)

@ -683,4 +683,67 @@
</set> </set>
WHERE deviceRecordKey = #{deviceRecordKey} WHERE deviceRecordKey = #{deviceRecordKey}
</update> </update>
<insert id="updateProductInfoData" parameterType="com.glxp.udidl.admin.entity.udi.ProductInfoEntity">
REPLACE
INTO productinfo
(id, nameCode, packRatio, packLevel, bhxjsl,
bhzxxsbzsl, zxxsbzbhsydysl, bhxjcpbm, bzcj, thirdProductNo, addType, deviceRecordKey, isUseDy,
thirdProductName,
cpmctymc, cplb, flbm, ggxh, qxlb, tyshxydm, ylqxzcrbarmc, zczbhhzbapzbh, ylqxzcrbarywmc, uuid, sjcpbm,
versionNumber
, diType, scbssfbhph, scbssfbhxlh, scbssfbhscrq, scbssfbhsxrq,
ybbm, spmc, cphhhbh, cpms, cpbsbmtxmc, isNewest, updateTime, hchzsb, cplx, sfwblztlcp, cgzmraqxgxx, sfbjwycxsy,
zdcfsycs,
sfwwjbz, syqsfxyjxmj, mjfs, qtxxdwzlj, categoryName)
values (#{id},
#{nameCode},
#{packRatio},
#{packLevel},
#{bhxjsl},
#{bhzxxsbzsl},
#{zxxsbzbhsydysl},
#{bhxjcpbm},
#{bzcj},
#{thirdProductNo},
#{addType},
#{deviceRecordKey},
#{isUseDy},
#{thirdProductName},
#{cpmctymc},
#{cplb},
#{flbm},
#{ggxh},
#{qxlb},
#{tyshxydm},
#{ylqxzcrbarmc},
#{zczbhhzbapzbh},
#{ylqxzcrbarywmc},
#{uuid},
#{sjcpbm},
#{versionNumber},
#{diType},
#{scbssfbhph},
#{scbssfbhxlh},
#{scbssfbhscrq},
#{scbssfbhsxrq},
#{ybbm},
#{spmc},
#{cphhhbh},
#{cpms},
#{cpbsbmtxmc},
#{isNewest},
#{updateTime},
#{hchzsb},
#{cplx},
#{sfwblztlcp},
#{cgzmraqxgxx},
#{sfbjwycxsy},
#{zdcfsycs},
#{sfwwjbz},
#{syqsfxyjxmj},
#{mjfs},
#{qtxxdwzlj},
#{categoryName})
</insert>
</mapper> </mapper>

Loading…
Cancel
Save