热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Spring Data Jpa如何实现自定义方法

这篇文章将为大家详细讲解有关Spring Data Jpa如何实现自定义方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文

这篇文章将为大家详细讲解有关Spring Data Jpa如何实现自定义方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

    Spring Data Jpa 自定义方法的实现

    最近项目中用到了Spring Data JPA,在里面我继承了一个PagingAndSortingRepository的接口,期望的是利用Spring Data JPA提供的便利。

    同时我也希望自己有一个能定义自己方法的接口,因为单纯靠Spring Data JPA中提供的功能还是有很多业务逻辑实现不了,我必须自己实现。

    那么问题来了:Spring Data JPA好处就是让我们省去了实现接口的过程,按照他们给的命名规范他们会自动实现我们的业务逻辑,那我们自己实现的接口要怎么注入到其中呢?

    上网查找了好多资料,都没有说的太详细,更多的是照搬胡抄,这里是我亲自写的,可能很多人会用到,不多说上代码:

    自己的接口

    package com.mhc.dao; 
    import org.springframework.stereotype.Repository; 
    import com.mhc.entity.Person;
     
    @Repository
    public interface DeviceCategoryDaoCustom {
     public Person getsFather(Person person); 
    }

    主接口

    public interface DeviceCategoryDao extends
      PagingAndSortingRepository, DeviceCategoryDaoCustom {  
    }

    上面是我的接口继承PagingAndSortingRepository、DeviceCategoryDaoCustom(我自己方法的接口)。

    我新建一个类来实现我自己的接口

    package com.mhc.dao; 
    import javax.persistence.PersistenceContext;
    import javax.transaction.Transactional; 
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.data.repository.CrudRepository;
    import org.springframework.data.repository.NoRepositoryBean;
    import org.springframework.stereotype.Component;
    import org.springframework.stereotype.Repository;
    import org.springframework.stereotype.Service; 
    import com.mhc.entity.Person;
     
    @Repository("crudRepositoryDaoCustom")
    class DeviceCategoryDaoImpl implements DeviceCategoryDaoCustom {
     
     @Transactional
     public Person getsFather(Person person) {
      // TODO Auto-generated method stub
      Person father = new Person();
      father = person.getParentPerson();
      return father;
     }
    }

    在这里有个需要注意的地方,就是用不用implements的问题,如果用的话,他就会调用编译器的实现功能去实现我们自定义的接口也就是:DevicecategoryCustom。

    如果去掉的话,他会去实现DeviceCategoryDao,那么会有人问,他怎么去自己找的呢。

    事实上他是根据后面的Impl来寻找的。他不会提示@override,不过你写相同的方法他还是会覆盖(覆盖主接口中的同名方法,如果有的话)DeviceCategoryDao中的同名方法。你可以去尝试一下。

    同时加上@Repository把他加入到Bean里面,这样下次用这个方法的时候Repository会自动找到他的(话说Spring团队真心NB)。然后我们交给spring托管、测试。。。。。Ok 真心赞

    Spring Data Jpa自定义方法关键字

    关键字方法名举例对应的SQL
    AndfindByNameAndAgewhere name = ? and age = ?
    OrfindByNameOrAgewhere name = ? or age = ?
    IsfindByNameIswhere name = ?
    EqualsfindByNameEqualswhere name = ?
    BetweenfindByAgeBetweenwhere age between ? and ?
    LessThanfindByAgeLessThanwhere age
    LessThanEqualsfindByAgeLessThanEqualwhere age <= ?
    GreatorThanfindByAgeGreaterThanwhere age > ?
    GreatorThanEqualsfindByAgeGreaterThanEqualwhere age >= ?
    AfterfindByAgeAfterwhere age > ?
    BeforefindByAgeBeforewhere age
    IsNullfindByNameIsNullwhere name is null
    IsNotNull,NotNullfindByNameIsNotNull,findByNameNotNullwhere name is not null
    NotfindByNameNotwhere name <>?
    InfindByAgeInwhere age in (?)
    NotInfindByAgeNotInwhere age not in (?)
    NotLikefindByNameNotLikewhere name not like ?
    LikefindByNameLikewhere name like ?
    StartingWithfindByNameStartingWithwhere name like ‘?%&#39;
    EndingWithfindByNameEndingWithwhere name like ‘%?&#39;
    Containing,ContainsfindByNameContaining,findByNameContainswhere name like ‘%?%&#39;
    OrderByfindByOrderByAgeDescorder by age desc
    TruefindByBossTruewhere boss = true
    FalsefindByBossFalsewhere boss = false
    IgnoreCasefindByNameIgnoreCasewhere UPPER(name) = UPPER(?)

    关于“Spring Data Jpa如何实现自定义方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。


    推荐阅读
    • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
    • Spring特性实现接口多类的动态调用详解
      本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
    • SpringMVC接收请求参数的方式总结
      本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
    • Java如何导入和导出Excel文件的方法和步骤详解
      本文详细介绍了在SpringBoot中使用Java导入和导出Excel文件的方法和步骤,包括添加操作Excel的依赖、自定义注解等。文章还提供了示例代码,并将代码上传至GitHub供访问。 ... [详细]
    • Java太阳系小游戏分析和源码详解
      本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
    • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
    • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
    • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
      本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
    • [大整数乘法] java代码实现
      本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
    • 标题: ... [详细]
    • Android源码深入理解JNI技术的概述和应用
      本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
    • r2dbc配置多数据源
      R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
    • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
    • JDK源码学习之HashTable(附带面试题)的学习笔记
      本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
    • (三)多表代码生成的实现方法
      本文介绍了一种实现多表代码生成的方法,使用了java代码和org.jeecg框架中的相关类和接口。通过设置主表配置,可以生成父子表的数据模型。 ... [详细]
    author-avatar
    2012我的语言
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有