我最喜欢的Mybatis 3.5新特性!超实用!

栏目: Java · 发布时间: 5年前

内容简介:作者:周立 来源:it牧场相信大家使用Mybatis时代码是这样写的:

作者:周立 来源:it牧场

Mybatis 3.5 发布有段时间了,终于支持了  Optional ,这么实用的特性,竟然还没人安利……于是本文出现了。

新特性比较简单,但非常实用,因为能大量简化恶心的判空代码。

TIPS

简单起见——

本文直接用Mybaits的注解式编程,不把 SQL 独立放在xml文件了 省略Service,直接Controller调用DAO

Before

相信大家使用Mybatis时代码是这样写的:


 

@Mapper

public interface UserMapper {

@Select("select * from user where id = #{id}")

User selectById(Long id);

}

然后,业务代码是这样写的:


 

public class UserController {

@Autowired

private UserMapper userMapper;


@GetMapping("/{id}")

public User findById(@PathVariable Long id) {

User user = this.userMapper.selectById(id);

if(user == null) {

// 抛异常,或者做点其他事情

}

}

}

After

Mybatis 3.5支持Optional啦!你的代码可以这么写了:


 

@Mapper

public interface UserMapper {

@Select("select * from user where id = #{id}")

Optional<User> selectById(Long id);

}

然后,业务代码可以变成这样:


 

public class UserController {

@Autowired

private UserMapper userMapper;


@GetMapping("/{id}")

public User findById(@PathVariable Long id) {

return this.userMapper.selectById(id)

.orElseThrow(() -> new IllegalArgumentException("This user does not exit!"));

}

}

从此,再也不需要像以前一样写一大堆代码去判断空指针了。

至于 Optional 怎么使用,本文不作赘述——JDK 12都发布了,你要我普及JDK 8的”新特性”吗?大家自行百度吧,百度很多了。关键词: Java 8 Optional

思考

Mybatis 已支持  OptionalMybatis Spring Boot Starter 也已跟进,引入如下依赖即可:


 

<dependency>

<groupId>org.mybatis.spring.boot</groupId>

<artifactId>mybatis-spring-boot-starter</artifactId>

<version>2.0.0</version>

</dependency>

然而, Mybatis 的配套设施尚未跟进——

官方提供的  Mybatis Generator 插件还未跟进,这意味着目前使用该插件生成的代码依然不会返回  Optional ,例如  selectByPrimaryKey ,返回的依然是  实体类 ,而非  Optional<实体类> 国内最流行的第三方Mybaits增强  Mybatis通用Mapper [1]  ,及其配套的  通用Mapper专用生成器 [2]  都尚未支持 Optional  ,笔者提Issue,详见: 建议支持Optional [3]  ,其实想支持很简单,只需稍作修改即可。看最近时间,考虑提交PR。

balabala

Spring Data (jpa、 redis 、mongo…)花了很大力气重构(很多包名都换了,API名称也改了),率先支持了  Optional ,不得不说,在 Java 世界,  Spring 确实走在前面,引领着Java圈子的潮流。

我最喜欢的Mybatis 3.5新特性!超实用!

我最喜欢的Mybatis 3.5新特性!超实用!

我最喜欢的Mybatis 3.5新特性!超实用!


以上所述就是小编给大家介绍的《我最喜欢的Mybatis 3.5新特性!超实用!》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Spark大数据分析技术与实战

Spark大数据分析技术与实战

董轶群、曹正凤、赵仁乾、王安 / 电子工业出版社 / 2017-7 / 59.00

Spark作为下一代大数据处理引擎,经过短短几年的飞跃式发展,正在以燎原之势席卷业界,现已成为大数据产业中的一股中坚力量。 《Spark大数据分析技术与实战》着重讲解了Spark内核、Spark GraphX、Spark SQL、Spark Streaming和Spark MLlib的核心概念与理论框架,并提供了相应的示例与解析。 《Spark大数据分析技术与实战》共分为8章,其中前4......一起来看看 《Spark大数据分析技术与实战》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码