欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

继承JpaRepository后,找不到findOne()方法的解决

程序员文章站 2022-03-03 08:04:47
目录继承jparepository,找不到findone()方法springdatajpa:消失的findone()继承jparepository,找不到findone()方法问题:以前一直使用fin...

继承jparepository,找不到findone()方法

问题:

以前一直使用findone(id id);,这次用springboot构建新项目后,并没有找到这个findone(id id),只有另外的

继承JpaRepository后,找不到findOne()方法的解决

分析:

看了下jpa的依赖,因为springboot的版本是2.0.0的,所以spring-data-jpa的版本也是2.0.x。

拿2.0.5的源码和之前可行的1.11.9做了对比。

继承JpaRepository后,找不到findOne()方法的解决

对比crudrepository接口中:

继承JpaRepository后,找不到findOne()方法的解决

各种方法名改变蒙蔽。。然而其实也一样,不过findone方法的返回值也改了,变成了optional<t>。

optional是java8的新特性之一,它显示的告诉调用者该值可能是空值,需要做出判断,避免出现空指针异常。

其中:

t orelse(t other)

当值存在就会直接返回值,如果不存在会返回别的值(指定默认值)。

继承JpaRepository后,找不到findOne()方法的解决

t orelsethrow(supplier<? extends x> ex)

与 orelse() 不同的地方是不存在时则抛出异常

继承JpaRepository后,找不到findOne()方法的解决

t get() boolean ispresent()

get()方法可以获取到值,但是直接这样写的话如果值不存在就要抛异常。所以要先通过ispresent()做判断,值存在再get()。

继承JpaRepository后,找不到findOne()方法的解决继承JpaRepository后,找不到findOne()方法的解决

void ifpresent(consumer<? super t> consumer)

如果值存在则执行该代码段 , 否则不做任何事情。

继承JpaRepository后,找不到findOne()方法的解决

consumer<t> 是函数式接口,可使用lambda表达式处理。

继承JpaRepository后,找不到findOne()方法的解决

解决:

具体用法:

继承JpaRepository后,找不到findOne()方法的解决

更详细的可以去了解optional类,评论中有老哥建议使用第三种ifpresent(),如果熟悉lambda表达式的可以使用。我以往都是使用第一种

或者在不存在时抛出自定义异常

coursebaserepository.findbyid(id).orelsethrow(() -> new courseexception("course does not exist!"));

springdatajpa:消失的findone()

昨日,当转战idea进行java代码的编写,首先配置了一个springboot+mybatis+springdatajpa的一个简单框架,用以熟悉springdatajpa和idea基本操作。但是在编写代码的时候出现了问题:findone(id id),这个方法没有找不到了。

进行思考

思考1:findone()这个方法是谁的,通过比较发现是crudrepository里面的一个方法,但是自己继承的是jparepositoty,所以无法执行。但是为什么之前eclipse上面可以执行?同样继承的是jpa。

思考2:为什么继承的是jpa,但是却可以使用crud里面的方法。发现jpa是crud的孙子辈,所以可以继承。

思考3:为什么可以继承但是找不到这个方法,通过比较,发现crud部分的源代码不一样了,版本不一样了,因此出现了问题。

思考4:为什么版本不同,及解决方案

  • pom文件指定jpa版本。但是没有效果。
  • 发现springboot升级到了springboot x,不支持findone()。对pom文件进行修改,强行降级别到1.5.6。
  • 使用getone(),或者findbyid().get(),注意findbyid()的返回值optional,有可能存在空值,所以不能直接写.get()。要进行非空的判断。

对jpa的思考

  • 优点:对于单表的增删改查而言,操作起来极其简单方便。同样也可以利用其所制定的命名规则来完成一些增删改查。也可以利用sql语句来实现相关的查询。
  • 缺点:对于多表操作而言,不如mybatis简单,而是比较复杂。对于只查询部分字段的操作,也是同样的道理。扩展性差。
  • 想法:利用jpa和mybatis的综合使用,利用jpa来进行简单的增删改查。利用mybatis进行多表操作,提升程序的扩展性。但是可能会出现jpa和mybatis的冲突。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。