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 语法错误。
相关推荐
shuair1 小时前
idea 2023.3.7常用插件
java·ide·intellij-idea
小安同学iter2 小时前
使用Maven将Web应用打包并部署到Tomcat服务器运行
java·tomcat·maven
Yvonne9782 小时前
创建三个节点
java·大数据
不会飞的小龙人3 小时前
Kafka消息服务之Java工具类
java·kafka·消息队列·mq
是小崔啊3 小时前
java网络编程02 - HTTP、HTTPS详解
java·网络·http
brevity_souls4 小时前
Spring Boot 内置工具类
java·spring boot
小钊(求职中)4 小时前
Java开发实习面试笔试题(含答案)
java·开发语言·spring boot·spring·面试·tomcat·maven
shix .4 小时前
什么是tomcat
java·tomcat
java技术小馆4 小时前
Deepseek整合SpringAI
java·spring cloud
天荒地老笑话么4 小时前
Mac安装配置Tomcat 8
java·macos·tomcat