MyBatis 默认的 update 操作对 null 属性的处理方式

背景

本文将介绍三个开发过程中的小技术点:

  1. Vue 组件传递对象时,根据是否会修改原对象内容,决定是直接使用,还是用副本;
  2. Spring 容器托管的实体 Bean 名称的基本规则;
  3. MyBatis 默认的 update 操作对 null 属性的处理方式。

Vue 子组件中使用属性的副本

Vue 前端开发过程中,父组件引用某个子组件时,可以直接传递对象属性给子组件。如果子组件只是引用数据,而不对数据进行修改,这个用法没问题。

如果子组件需要修改该数据,且有"确定"、"取消"按钮来决定是否保存数据,就不能直接用父组件传来的数据,因为"取消"操作不应该修改父组件的数据。

正确的方法是,在子组件中使用副本接收父组件的数据,放入自己独立的属性中,本组件引用自己的数据:

javascript 复制代码
const copyArray = JSON.parse(JSON.stringify(data))

结论:Vue 是基于数据驱动的,而数据又是以对象呈现的,组件直接对对象操作时,引用地址相同,所以需要注意全局引用过程中数据的一致性。

Spring 托管的 Bean 名称生成规则

基于 Spring 容器的开发过程中,习惯了各种 @Autowired 自动注入后,如果有某些普通类,例如自定义的定时任务,webmagic 的落地处理类等,需要获取 Spring 托管的实体类,怎么办呢?

答案是自定义一个 @Component 注解标识的工具类,从 SpringContext 获取实例。

被 @Service 或 @Component 自动扫描的类,通过 getBean 获取时,它的 beanName 是什么呢?

Spring 存储 Bean 实例到容器时,名称命名的规则有两点需要了解:

  1. 常规类,类名首字母小写;例如 UserService ,对应 userService
  2. 非常规类,比如 ABCUserService ,以超过两个大写字母开头的类。与类名一致,对应 ABCUserService。

MyBatis 默认的 update 操作

MyBatis 的 BaseMapper 类封装了增删改查等常用方法,update 的方法需要注意的一点是,传入实体的某个属性为 null 时,它会将数据库中该实体对应的表的字段更新为 null 吗?

结论是:不会

如果需要根据实体的属性值,严格更新数据库,那么需要自定义 update 方法。不排除开发中有这种需求,即需要将某列修改为 null ,此时默认方法就不满足需求。

最后,总结 MyBatis 框架使用默认配置能正确开发的两个前提:

  1. 数据库表字段多单词间用 "_" 连接,对应实体属性符合驼峰命名规则;
  2. 数据库表字段中没有数据库的保留关键字,因为它不会处理转义。例如 MySQL 的 option 是一个保留关键字,MyBatis 自动操作有该列名的表时,会发生 SQL 语法错误。
相关推荐
JAVA学习通2 小时前
北京明光云振铎数据科技Java面经
java·开发语言·科技
贫民窟的勇敢爷们8 小时前
SpringBoot整合AOP切面编程实战,实现日志统一记录+接口权限校验
java·spring boot·spring
AC赳赳老秦9 小时前
供应链专员提效:OpenClaw自动跟踪物流信息、更新库存数据,异常自动提醒
java·大数据·服务器·数据库·人工智能·自动化·openclaw
迈巴赫车主9 小时前
Java基础:list、set、map一遍过
java·开发语言
灵犀学长9 小时前
基于 Spring ThreadPoolTaskScheduler + CronTrigger 实现的动态定时任务调度系统
java·数据库·spring
好家伙VCC11 小时前
【无标题】
java
小碗羊肉11 小时前
【JavaWeb | 第十一篇】文件上传(本地&阿里云OSS)
java·阿里云·servlet
吾疾唯君医11 小时前
Java SpringBoot集成积木报表实操记录
java·spring boot·spring·导出excel·积木报表·数据文件下载
Byron Loong12 小时前
【c++】为什么有了dll和.h,还需要包含lib
java·开发语言·c++
hexu_blog12 小时前
vue+java实现图片批量压缩
java·前端·vue.js