程序员晋级之路——java对象定义技巧使你的mybatis更具可读性

简介: 程序员晋级之路——java对象定义技巧使你的mybatis更具可读性

前言


作为一名在三四线城市艰难生存了3年的程序员,我会将日常工作中学到的看到的和大家一起分享,一起成长,希望我们的晋级之路完章的时候我们都可以成长为自己期待的样子!

其实所谓的对象定义技巧是我在公司外包出去的一个springmvc项目中发现的。如果说这个外包项目有任何一丢丢可取指出,我觉着就是对象定义的方式了!


实体结构


我们在mybatis中肯定会定义select语句、insert语句、update语句与delete语句。

以对学生类的增删该查操作,举个栗子:

首先是项目结构:

image.png

定义如图所示的student的对象

image.png


现需要实现对学生信息的有条件查询:

controller:

image.png

service:

image.png

dao:

image.png

我们在xml文件中定义一个查询语句,此时传入的参数是一个StydentDO类型的对象:

image.png


如果我们想要查询所有18岁的女生我们需要在controller层传入参数:

image.png

我们看到在简单的select语句中我们传入一个实体本身没有任何问题,同理在delete中和insert中也应该没有问题。

但是当我们进行update语句执行的时候会发现我们只传入一个StudentDO对象好像有点不够用,具体如下:

image.png

如上图所示一个,如果我们想把名字叫张三的人名字改为李四,我们传入的对象StudentDO中的name既要作为条件来储存”张三“,又要作为被更新的数据储存”李四“,这样显然是不行的。我们只能传入两个StudentDO对象其中一个存放条件,一个存放需要更新的数据,于是StudentWhere对象就出现了:

image.png

StudentWhere对象继承StudentDO对象,所以StudentDO里面的所有属性都可以写入到StudentWhere中,同时还可以将分页信息、排序信息、ids等其他东西放入,比如我们现在把名字叫”张三“的人名字改为”李四“,可以使用studentwhere.setName(“张三”)存放更新条件,studentdo.setName(“李四”)来存放更新数据。

此时我们发现如果这样写的话我们需要向xml中传入两个参数,这样肯定是不行的,所以我们需要再定义一个父容器将where和do存放进去,这就是StudentParam对象:

image.png

在StudentParam定义的时候我们可以看到StudentDO类型的变量为什么叫xdo,StudentWhere类型的变量为什么叫做where,其实主要是为了我们在写xml文件时更省力,这个一会儿再说,言归正传看一下我们怎么完成update语句的:

controller:

image.png

service:

image.png

mapper:

image.png

这种写法表面上我们会增加很多代码量,但是逻辑更加清晰同时我们的代码复用率可以大幅提高,比如我们使用的xdo和where可以直接复制到其他mapper中使用只需要改改字段就可以了。最重要的是即便有比较复杂的逻辑关系也能让你的新同事快速理清思路迅速上手,还有什么比这更重要的吗?

当然在生产中我更喜欢将mapper中的where语句、set语句、key和value提取出来,同时我们会在前端构建所有参数你看到的或许只是:

controller:

image.png

service:

image.png

作为一名勤劳的程序员知识面与思路固然重要,但是当我们还没有足够的积累的时候何不手头最简单的工作做起——代码规范。

如果你觉得这篇博客对你有帮助,那敬请期待我们的正餐吧——使用反射完美解决 pagehelper分页不准确的问题!我会在近期将文章整理出来!


相关文章
|
2月前
|
Java 程序员
JAVA程序员的进阶之路:掌握URL与URLConnection,轻松玩转网络资源!
在Java编程中,网络资源的获取与处理至关重要。本文介绍了如何使用URL与URLConnection高效、准确地获取网络资源。首先,通过`java.net.URL`类定位网络资源;其次,利用`URLConnection`类实现资源的读取与写入。文章还提供了最佳实践,包括异常处理、连接池、超时设置和请求头与响应头的合理配置,帮助Java程序员提升技能,应对复杂网络编程场景。
80 9
|
3天前
|
安全 Java 数据库连接
Java使用MyBatis-Plus的OR
通过MyBatis-Plus的条件构造器,Java开发者可以方便地进行复杂的查询条件组合,包括AND和OR条件的灵活使用。熟练掌握这些技巧,可以显著提升开发效率和代码可读性。
37 20
|
2天前
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
33 6
|
2天前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
13 2
|
2天前
|
SQL Java 数据库连接
【潜意识Java】深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
10 1
|
2天前
|
SQL Java 数据库连接
【潜意识Java】深入理解MyBatis,从基础到高级的深度细节应用
本文详细介绍了MyBatis,一个轻量级的Java持久化框架。内容涵盖MyBatis的基本概念、配置与环境搭建、基础操作(如创建实体类、Mapper接口及映射文件)以及CRUD操作的实现。此外,还深入探讨了高级特性,包括动态SQL和缓存机制。通过代码示例,帮助开发者更好地掌握MyBatis的使用技巧,提升数据库操作效率。总结部分强调了MyBatis的优势及其在实际开发中的应用价值。
11 1
|
13天前
|
Java
java代码优化:判断内聚到实体对象中和构造上下文对象传递参数
通过两个常见的java后端实例场景探讨代码优化,代码不是优化出来的,而是设计出来的,我们永远不可能有专门的时间去做代码优化,优化和设计在平时
29 15
|
12天前
|
SQL Java 数据库连接
Java MyBatis 面试题
Java MyBatis相关基础面试题
|
2月前
|
安全 Java 编译器
Java对象一定分配在堆上吗?
本文探讨了Java对象的内存分配问题,重点介绍了JVM的逃逸分析技术及其优化策略。逃逸分析能判断对象是否会在作用域外被访问,从而决定对象是否需要分配到堆上。文章详细讲解了栈上分配、标量替换和同步消除三种优化策略,并通过示例代码说明了这些技术的应用场景。
Java对象一定分配在堆上吗?
|
2月前
|
SQL 存储 Java
面向 Java 程序员的 SQLite 替代品
SQLite 是轻量级数据库,适用于小微型应用,但其对外部数据源支持较弱、无存储过程等问题影响了开发效率。esProc SPL 是一个纯 Java 开发的免费开源工具,支持标准 JDBC 接口,提供丰富的数据源访问、强大的流程控制和高效的数据处理能力,尤其适合 Java 和安卓开发。SPL 代码简洁易懂,支持热切换,可大幅提高开发效率。

热门文章

最新文章