当前位置: 首页 > wzjs >正文

crm客户关系管理平台做网站建设优化的公司排名

crm客户关系管理平台,做网站建设优化的公司排名,钢城网站建设,网站建设 大公司小公司前言 业务中常见需要修改表格某个字段的需求,传统的实现方式需要每个字段编写接口,存在重复开发,效率低的问题。可以设计个批量修改的接口,实现自定义修改需要的字段。 核心代码 入参 ApiModelProperty("主键")NotEm…

前言

业务中常见需要修改表格某个字段的需求,传统的实现方式需要每个字段编写接口,存在重复开发,效率低的问题。可以设计个批量修改的接口,实现自定义修改需要的字段。

核心代码

入参

    @ApiModelProperty("主键")@NotEmpty(message = "主键列表不能为空")private List<Long> ids;@ApiModelProperty("批量操作字段")@NotNull(message = "更新字段不能为null")private String updateFieldName;@ApiModelProperty("批量操作值")private Object updateFieldValue;@ApiModelProperty(value = "批量操作类型,update/clear/append")@NotNull(message = "批量操作类型不能为null")private String batchType;

枚举类

@Getter
@AllArgsConstructor
public enum BatchUpdateBatchTypeEnum {CLEAR("clear", "清除"),UPDATE("update", "修改"),APPEND("append", "追加"),;private String code;private String msg;//添加根据code获取枚举对象的方法public static BatchUpdateBatchTypeEnum getByCode(String code) {for (BatchUpdateBatchTypeEnum item : values()) {if (item.getCode().equals(code)) {return item;}}return null;}
}

修改方法

@Overridepublic void batchUpdate(BatchUpdateParam updateParam) throws NoSuchFieldException {BatchUpdateBatchTypeEnum batchTypeEnum = BatchUpdateBatchTypeEnum .getByCode(updateParam.getBatchType());if (batchTypeEnum == null) {throw new RuntimeException("批量操作类型错误");}Object value = updateParam.getUpdateFieldValue();boolean isList = false;if (value instanceof List) {isList = true;if (batchTypeEnum == BatchUpdateBatchTypeEnum .UPDATE) {value = JsonUtils.toJsonString(value);}} else if (batchTypeEnum == BatchUpdateBatchTypeEnum .APPEND) {//数据类型不是列表,不允许appendthrow new RuntimeException("数据类型不是列表,不允许append");}String fieldName = updateParam.getUpdateFieldName();//这里用的mybatisPlus的方法,如果没有的话使用反射也可以,主要是判断字段是否存在的ColumnCache columnCache = LambdaUtils.getColumnMap(IgShippingDemandDO.class).entrySet().stream().filter(e ->e.getKey().equalsIgnoreCase(fieldName)).map(Map.Entry::getValue).findAny().orElse(null);if (columnCache == null) {throw new RuntimeException("字段不存在");}if (batchTypeEnum == BatchUpdateBatchTypeEnum .CLEAR) {UpdateWrapper<UserDO> updateWrapper = new UpdateWrapper<UserDO>().in("id", updateParam.getIds()).set(columnCache.getColumn(), null);mapper.update(null, updateWrapper);} else {//update或者append校验参数类型是否都是list或者都不是if ((isList && UserDO.class.getDeclaredField(fieldName).getType() != List.class)|| (!isList && UserDO.class.getDeclaredField(fieldName).getType() == List.class)) {throw new RuntimeException("数据类型错误");}if (batchTypeEnum == BatchUpdateBatchTypeEnum .UPDATE) {UpdateWrapper<UserDO> updateWrapper = new UpdateWrapper<UserDO>().in("id", updateParam.getIds()).set(columnCache.getColumn(), value);mapper.update(null, updateWrapper);} else if (batchTypeEnum == BatchUpdateBatchTypeEnum .APPEND) {List<UserDO> userDOS = new ArrayList<>();//追加数据,如何实现for (Long batchId : updateParam.getIds()) {UserDO userDO = mapper.selectById(batchId);if (userDO == null) {continue;}//根据columnCache.getColumn()反射获取属性点值,并且将list的值合并进去,并且去重try {Field field = UserDO.class.getDeclaredField(fieldName);field.setAccessible(true); // 确保可以访问私有字段List<Object> list = getObjectList(field.get(userDO), value);UserDO userDOUpdate = new UserDO();userDOUpdate.setId(userDOUpdate.getId());//根据反射设置fieldName的值field.set(userDOUpdate, list);userDOS.add(userDOUpdate );} catch (Exception e) {throw new RuntimeException("字段错误");}}mapper.updateBatch(userDOS);}}}@Nullableprivate static List<Object> getObjectList(Object object, Object value) {if (object == null) {return  (List<Object>) value;}List<Object> list = (List<Object>)object;//将value的值合并进去,并且去重List<Object> valueList =  (List<Object>) value;for (Object o : valueList) {if (!list.contains(o)) {list.add(o);}}return list;}

前端界面

要更改的字段是列表的时候,可以追加的时候才展示追加字段值,不是列表的时候不展示

 

总结 

通过优化更改接口,只需要前段传入要更改的字段和值,即可实现表格任意字段的更改,减少了开发量,提高了开发效率。

http://www.dtcms.com/wzjs/316166.html

相关文章:

  • 公司简介简短点的百度地图排名可以优化吗
  • 手机网站建设比较好的公司重庆网站优化公司
  • 广州品牌网站营销软文
  • php众筹网站程序源码怎么制作网页里面的内容
  • 网站制作培训中心免费外链代发平台
  • 简述企业网站建设的流程百度指数对比
  • 聊城网站建设电话seo怎么做教程
  • 制作小程序代码汕头seo排名公司
  • 百度做网站投广告营销方法有哪些
  • 鹤壁建设网站推广哪家靠谱广告引流推广平台
  • 网站制作开发及优化是什么网站优化价格
  • 营销网站建设推广微信小程序怎么做
  • 网站开发毕业设计周志百度官方网站首页
  • 刘琪 找谁做网站靠谱东莞做网站推广
  • 零基础自学网站建设建网站找哪个公司
  • 怎么网站制作十大舆情网站
  • 中国今天刚刚发生的新闻辽宁好的百度seo公司
  • 手机网站改版了seo如何优化网站推广
  • 常州网站建设公司机构百度收录怎么做
  • wordpress规则百度seo排名优化联系方式
  • 大连凯杰建设有限公司网站网站seo服务
  • 网站备案去哪里备案卡一卡二卡三入口2021
  • 自己做网站还能挣钱吗企业网站制作与维护
  • 海南网站设计网页模板免费下载
  • 国家开发投资集团绍兴seo网站优化
  • 淘宝客优惠卷网站模板seo长尾关键词优化
  • 网站开发合肥长沙网站优化seo
  • 网站建设一次线上运营推广方案
  • 营销型网站建设概述哈尔滨seo关键词优化
  • 武汉本地最大的社区网站市场营销策划书范文5篇精选