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 语法错误。
相关推荐
Amor风信子1 分钟前
华为OD机试真题---跳房子II
java·数据结构·算法
杨荧27 分钟前
【JAVA开源】基于Vue和SpringBoot的洗衣店订单管理系统
java·开发语言·vue.js·spring boot·spring cloud·开源
陈逸轩*^_^*44 分钟前
Java 网络编程基础
java·网络·计算机网络
这孩子叫逆1 小时前
Spring Boot项目的创建与使用
java·spring boot·后端
星星法术嗲人1 小时前
【Java】—— 集合框架:Collections工具类的使用
java·开发语言
一丝晨光1 小时前
C++、Ruby和JavaScript
java·开发语言·javascript·c++·python·c·ruby
天上掉下来个程小白1 小时前
Stream流的中间方法
java·开发语言·windows
xujinwei_gingko2 小时前
JAVA基础面试题汇总(持续更新)
java·开发语言
liuyang-neu2 小时前
力扣 简单 110.平衡二叉树
java·算法·leetcode·深度优先
一丝晨光2 小时前
Java、PHP、ASP、JSP、Kotlin、.NET、Go
java·kotlin·go·php·.net·jsp·asp