当前位置: 首页 > news >正文

数据仓库层Repository(CrudRepository、PagingAndSortingRepository、JpaRepository)

什么是数据仓库层Repository?

数据仓库接口的作用:Repository原意指的是仓库,即数据仓库的意思。Repository居于业务层和数据层之间,将两者隔离开来,在它的内部封装了数据查询和存储的逻辑。
Repository接口:
1、CrudRepository
在这里插入图片描述
2、PagingAndSortingRepository
在这里插入图片描述
3、JpaRepository
在这里插入图片描述
CrudRepository、PagingAndSortingRepository和JpaRepository三者的关系图如下所示:
在这里插入图片描述
综上所述,JpaRepository的功能最全、最强大,所以我们的数据仓库类继承JpaRepository
注意: 创建的数据仓库类是一个接口(不是抽象类、也不是普通类),针对这个接口添加注解@Repository。

Repository和DAO的区别

DAO是传统MVC中Model的关键角色,全称是Data Access Object。DAO直接负责数据库的存取工作,乍一看两者非常类似,但从架构设计上讲两者有着本质的区别:Repository是相对对象而言,DAO则是相对数据库而言,虽然可能是同一个东西 ,但侧重点完全不同。

JpaSpecificationExecutor

JpaSpecificationExecutor(用于特殊的业务场景如:既要有分页又要有排序,里面还有各种动态的查询,虽然此时通过JpaRepository能实现,但是JpaSpecificationExecutor更简单)
在这里插入图片描述

自定义接口继承JpaRepository

/*公司数据仓库接口(创建的数据仓库类是一个接口(不是抽象类、也不是普通类),针对这个接口添加注解@Repository。)*/
//类只能继承单个,但是接口可以继承多个
@Repository
public interface CompanyRepo extends JpaRepository<Company,String> {   // 指向对应的实体类Company,String与主键的类型一致(uuid string类型),如果是自增列则填写int// 原生sql语句查询,需要nativeQuery=true,如果为false则表示使用HQL语句@Query(value = "select * from company where comname=?1",nativeQuery = true)  // 精准查询List<Company> findByNativeSQL(String comname);  // 表示传入一个公司名称comname,那么就会把所有满足该名称的信息查询出来@Query(value="select * from company where comname like '%?1%'",nativeQuery = true)  // 模糊查询List<Company> findByNativeSQL1(String comname);//原生sql语句操作(涉及到数据变动的,如删除和更新,必须加注解@Modifying)@Modifying@Query(value = "update company set comaddress =?1 where comname=?2",nativeQuery = true)void updateByName(String comaddress,String comname);}
http://www.lryc.cn/news/4350.html

相关文章:

  • 大数据技术架构(组件)33——Spark:Spark SQL--Join Type
  • Linux: bash起后台进程引发的僵尸进程
  • 网络安全攻防中,Rock-ON自动化的多功能网络侦查工具,Burpsuite被动扫描流量转发
  • 电子技术——共模抑制
  • 对KMP简单的理解
  • Hibernate不是过时了么?SpringDataJpa又是什么?和Mybatis有什么区别?
  • 数学建模拓展内容:卡方检验和Fisher精确性检验(附有SPSS使用步骤)
  • 【Python学习笔记之七大数据类型】
  • Android系统之onFirstRef自动调用原理
  • ipv6上网配置
  • python实现聚类技术—复杂网络社团检测 附完整代码
  • 如何判断两架飞机在汇聚飞行?(如何计算两架飞机的航向夹角?)内含程序源码
  • Scipy稀疏矩阵bsr_array
  • LeetCode笔记:Weekly Contest 332
  • autox.js在vscode(win7)与雷神模拟器上的开发环境配置
  • 创建阿里云物联网平台
  • 【链式二叉树】数据结构链式二叉树的(万字详解)
  • Koa2篇-简单介绍及使用
  • Linux ALSA 之十一:ALSA ASOC Path 完整路径追踪
  • 【Spring Cloud总结】1、服务提供者与服务消费者快速上手
  • 若依项目学习之登录生成验证码
  • 计算机网络5:数据在两台计算机之间是怎样传输的?
  • 就现在!为元宇宙和Web3对互联网的改造做准备!
  • 【mysql数据库】
  • 【测试开发】web 自动化测试 --- selenium4
  • Elasticsearch7.8.0版本进阶——路由计算
  • c#反射-获取属性和字段的值
  • 前后端分离-小项目-1前端布局
  • 基于jsp的网络电子相册的设计与实现
  • Python快速上手系列--类--详解篇