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

河南网站建设软件wordpress 插件表

河南网站建设软件,wordpress 插件表,贵州遵义网,五金机械设备网站模板建设原因 因为 MyBatis-Plus 自带的更新方法#xff0c;都有对对象空值进行判空。只有不为空的字段才会进行数据更新 所以像updateById等方法#xff0c;在更新时会自动忽略为null的字段#xff0c;只更新非null字段值 但在某些情况下#xff0c;我们的需求就是将数据库中的值…原因 因为 MyBatis-Plus 自带的更新方法都有对对象空值进行判空。只有不为空的字段才会进行数据更新 所以像updateById等方法在更新时会自动忽略为null的字段只更新非null字段值 但在某些情况下我们的需求就是将数据库中的值设为null 此时mybatis-plus的原生方法将不生效需要我们手动写set的wrapper或则在xml中写set null的sql 但如果表字段非常多则需要写一段又臭又长的东西还非常耗时 解决方式一 在实体类对应的字段上加注解TableField(strategyFieldStrategy.IGNORED)忽略null值的判断例如 TableField(updateStrategy FieldStrategy.IGNORED) private String address;如果使用了这个注解在address为null时使用updateById等方法进行修改则生成的sql将是 set address null 这里有一个问题是使用该注解后这个属性就会全局忽略null值的判断 但可能在某些场景下我们想忽略某些场景下不忽略使用该注解就不能满足要求了。如果想实现这种效果可以使用方式二 解决方式二 方式二的思路很简单使用UpdateWrapper 在UpdateWrapper中我们可以判断属性为null则 UpdateWrapper.set(address, null);当字段非常多时如果手动拼写则代码又臭又长还很耗时。于是我写了一个工具类来帮助我自动生成UpdateWrapper import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;import java.lang.reflect.Field;/*** author: tanghaizhi* CreateTime: 2023/3/14 15:04* Description:*/ public class UpdateWrapperUtils {/*** 传入一个实体对象返回他的UpdateWrapper对象入股属性未null,在修改数据库时会set null* param r* param key where字段* param R* return* throws Exception*/public static R UpdateWrapperR generateUpdateWrapperByKey(R r, String key) throws Exception {UpdateWrapperR updateWrapper new UpdateWrapper();//获取类中所有的非继承自父类的字段(Field) 如果需要获取全部(包括继承自父类的)使用FieldUtils.getAllFields(r.getClass())Field[] field r.getClass().getDeclaredFields();for (Field f:field){f.setAccessible(true);if(key.equals(f.getName())){updateWrapper.eq(camelToUnderline(key),f.get(r));} else{TableField annotation f.getAnnotation(TableField.class);//先判断没带有注解TableField(exist false)if(annotation null || annotation.exist() ! false){if(f.get(r) null){updateWrapper.set(camelToUnderline(f.getName()),null);} else {updateWrapper.set(camelToUnderline(f.getName()),f.get(r));}}}}return updateWrapper;}/*** 这个方法接受一个字符串参数返回一个字符串将 Java 风格的字符串转换为数据库风格的字符串。例如将 userName 转换为 user_name。* param param* return*/public static String camelToUnderline(String param) {if (param null || param.isEmpty()) {return ;}StringBuilder sb new StringBuilder();char[] charArray param.toCharArray();for (int i 0; i charArray.length; i) {char c charArray[i];if (Character.isUpperCase(c)) {sb.append(_);}sb.append(Character.toLowerCase(c));}return sb.toString();}}工具类使用方法如下 RequestMapping(value /test)public void test() throws Exception {User user new User();user.setId(73850189L);user.setPhone(12346789);UpdateWrapperUser updateWrapper UpdateWrapperUtils.generateUpdateWrapperByKey(user,id);userMapper.update(null,updateWrapper);}我们新new的实例user除了id和phone其他属性都为null我们期望的效果是除了这两个字段其他的字段都被set为null 可以看到测试效果和预期效果一致 另注使用该方法需要mybatis-plus-boot-starter的版本在3.1.0及以上 dependencygroupIdcom.baomidou/groupIdartifactIdmybatis-plus-boot-starter/artifactIdversion3.1.0/version /dependency
http://www.w-s-a.com/news/799308/

相关文章:

  • 浙江网站推广爱企查企业查询入口
  • 公司网站平台vs2012网站开发课程设计
  • 哪些方法可以建设网站做网站失败
  • 龙岗网站建设技术wordpress左右两栏
  • 电子商务网站开发与应用的介绍怎么查询域名是否备案
  • 想做一个自己设计公司的网站怎么做的权威发布型舆情回应
  • 做ppt用的音效网站python基础教程网易
  • 可以做免费广告的网站有哪些做视频赚钱的国外网站
  • 苏州做物流网站电话郑州网站高端网站设计
  • 网站建设音乐插件怎么弄wordpress添加数据库文件
  • 汽车行业做网站福建省第二电力建设公司网站
  • delphi做网站开发商城网站建设价位
  • 网站宣传片3 阐述网站建设的步骤过程 9分
  • 公司网站怎么做站外链接哪里有做胎儿dna亲子鉴定
  • 潍坊做电商的网站建设wordpress 特效主题
  • 做网站和app哪个难公司网上注册系统
  • 关于网站建设外文文献系部网站建设
  • 高端设计网站都有哪些月付网站空间提供商
  • 家政 东莞网站建设优化设计官方电子版
  • 做网站如何使用网页插件上海造价信息网
  • 承德网站制作加盟天津做优化的网站有多少家
  • 北京市保障性住建设投资中心网站首页专业做网站联系电话
  • 镇江网站建设方式优化单页面网站教程
  • 做手机网站公司北京网页设计公司兴田德润实惠
  • 域名申请好了 要怎么做网站百度推广开户渠道
  • 电商网站建设 数商云焦作黄河交通学院
  • 做一个网站成本多少太原网站维护
  • 网站建设制作设计优化怎么制作网页步骤
  • 花都区pc端网站建设画册设计多少钱一页
  • 国外买域名的网站廊坊网站制作网页