首页
学习
活动
专区
圈层
工具
发布

一篇 SpringData+JPA 总结

概述 SpringData,Spring 的一个子项目,用于简化数据库访问,支持 NoSQL 和关系数据库存储 SpringData 项目所支持 NoSQL 存储 MongDB(文档数据库) Neo4j...(图形数据库) Redis(键/值存储) Hbase(列族数据库) SpringData 项目所支持的关系存储技术 JDBC JPA(本次重点) SpringData 整合 JPA 以及 HelloWorld...在 maven 项目的 test 目录下新建测试类测试 getPersonByPersonName(String personName) 方法(自动生成的数据表中已加入数据,Person 表和 Address...: 继承 CrudRepository,实现了一组分页排序相关的方法 JpaRepository: 继承 PagingAndSortingRepository,实现一组 JPA 规范相关的方法 自定义的...@Modifying 我们在 Spring 下配置了 service 包下的所有方法都会当做事务方法去处理,现在我们将进行更新操作,需要将其置一个事务方法,所以将接下来的测试方法放在 service 包下

1.8K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    什么是JPA?Java Persistence API简介

    使用JPA时,可以创建从数据存储区到应用程序的数据模型对象的映射。您可以定义对象和数据库之间的映射,而不是定义对象的保存和检索方式,然后调用JPA来保存它们。...虽然它们包含多种数据,但它们不包含任何业务逻辑。持久化数据对象是软件开发中普遍存在的挑战。 JDBC的数据持久性 将Musician类的实例保存到关系数据库的一种方法是使用JDBC库。...作为一个示例,名为Musician的类将默认映射到名为Musician的数据库表。 传统配置是节省时间的,并且在许多情况下它运行良好。也可以自定义JPA配置。...当JPA将一个 Musician或一个Performance 加载到数据库中时,它将使用此信息重新构建对象图。...我建议使用该persistence.xml文件,因为以这种方式存储依赖项使得在不修改代码的情况下更新应用程序非常容易。 JPA的Spring配置 使用Spring将极大地简化JPA与应用程序的集成。

    11.8K30

    Spring Boot第八章-Spring Data JPA

    Hibernate是数据访问解决技术的绝对霸主,使用O/R映射(Object-Relational Mapping) 技术实现数据访问,O/R映射即将领域模型类和数据库的表进行映射,通过程序操作对象而实现表数据操作的能力...2.定义数据访问层 只需要定义一个类继承JpaRepository的接口,就可以使用默认的数据访问操作方法。...3.配置使用Spring Data JPA 在Spring环境中,可以通过@EnableJpaRepositories注解开启Spring Data JPA的支持,@EnableJpaRepositories...@NameQuery,在数据库操作接口里使用 (4)@Query 这也是比较常见的查询了,用这个注解在接口的方法上实现查询,在sql语句里查询参数上可以用参数索引,从1开始,比如?...(6)排序与分页 Spring Data JPA提供了Sort类,page接口和Pageable接口,可以方便的排序和分页 (7)自定义Repository 我们可以将自己常用的数据库操作封装起来,自定义

    3.9K20

    SpringBoot(五) :spring data jpa 的使用

    spring data jpa Spring Data JPA 是 Spring 基于 ORM 框架、JPA 规范的基础上封装的一套JPA应用框架,可使开发者用极简的代码即可实现对数据的访问和操作。...预先生成方法 spring data jpa 默认预先生成了一些基本的CURD的方法,例如:增、删、改等等。...复杂查询 在实际的开发中我们需要用到分页、删选、连表等查询的时候就需要特殊的方法或者自定义SQL 分页查询 分页查询在实际使用中非常普遍了,spring data jpa已经帮我们实现了分页的功能,在查询的方法中...SQL查询 其实Spring data 觉大部分的SQL都可以根据方法名定义的方式来实现,但是由于某些原因我们想使用自定义的SQL来查询,spring data也是完美支持的;在SQL的查询方法上面使用...(basePackages = "com.neo.repositories.mongo") interface Configuration { } 其它 使用枚举 使用枚举的时候,我们希望数据库中存储的是枚举对应的

    1.5K30

    springboot(五):spring data jpa的使用

    在上篇文章springboot(二):web综合开发中简单介绍了一下spring data jpa的基础性使用,这篇文章将更加全面的介绍spring data jpa 常见用法以及注意事项 使用spring...1) 复杂查询 在实际的开发中我们需要用到分页、删选、连表等查询的时候就需要特殊的方法或者自定义SQL 分页查询 分页查询在实际使用中非常普遍了,spring data jpa已经帮我们实现了分页的功能...SQL查询 其实Spring data 觉大部分的SQL都可以根据方法名定义的方式来实现,但是由于某些原因我们想使用自定义的SQL来查询,spring data也是完美支持的;在SQL的查询方法上面使用...、事务支持 这里有一篇文章写的很清楚:Spring Boot多数据源配置与使用 异构数据库多源支持 比如我们的项目中,即需要对mysql的支持,也需要对mongodb的查询等。...(basePackages = "com.neo.repositories.mongo") interface Configuration { } 其它 使用枚举 使用枚举的时候,我们希望数据库中存储的是枚举对应的

    2.6K90

    干货|一文读懂 Spring Data Jpa!

    JPA包含的技术 ORM 映射元数据:JPA 支持 XML 和 JDK 5.0 注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中。...Spring Data Spring Data 是 Spring 的一个子项目。用于简化数据库访问,支持NoSQL 和 关系数据存储。其主要目标是使数据库的访问变得方便快捷。...Spring Data 具有如下特点: SpringData 项目支持 NoSQL 存储: MongoDB (文档数据库) Neo4j(图形数据库) Redis(键/值存储) Hbase(列族数据库)...SpringData 项目所支持的关系数据存储技术: JDBC JPA Spring Data Jpa 致力于减少数据访问层 (DAO) 的开发量....注意: JPQL 不支持使用 INSERT 方法的返回值应该是 int,表示更新语句所影响的行数 在调用的地方必须加事务,没有事务不能正常执行 默认情况下, Spring Data 的每个方法上有事务,

    3.7K20

    ORM和 Spring Data Jpa

    ORM 什么是“持久化” 持久化的主要应用是将内存中的数据存储在关系型的数据库中,当然也可以存储在磁盘文件中、XML数据文件中等等。...JPA包含的技术 ORM 映射元数据:JPA 支持 XML 和 JDK 5.0 注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中。...Spring Data Spring Data 是 Spring 的一个子项目。用于简化数据库访问,支持NoSQL 和 关系数据存储。其主要目标是使数据库的访问变得方便快捷。...Spring Data 具有如下特点: SpringData 项目支持 NoSQL 存储: MongoDB (文档数据库) Neo4j(图形数据库) Redis(键/值存储) Hbase...(列族数据库) SpringData 项目所支持的关系数据存储技术: JDBC JPA Spring Data Jpa 致力于减少数据访问层 (DAO) 的开发量.

    4.4K30

    Spring Boot2 系列教程(二十三)理解 Spring Data Jpa

    和 JDK 5.0 注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中。...1.2 Spring Data Spring Data 是 Spring 的一个子项目。用于简化数据库访问,支持NoSQL 和 关系数据存储。其主要目标是使数据库的访问变得方便快捷。...Spring Data 具有如下特点: SpringData 项目支持 NoSQL 存储: MongoDB (文档数据库) Neo4j(图形数据库) Redis(键/值存储) Hbase(列族数据库)...SpringData 项目所支持的关系数据存储技术: JDBC JPA Spring Data Jpa 致力于减少数据访问层 (DAO) 的开发量....注意: JPQL 不支持使用 INSERT 方法的返回值应该是 int,表示更新语句所影响的行数 在调用的地方必须加事务,没有事务不能正常执行 默认情况下, Spring Data 的每个方法上有事务,

    2.8K10

    走进Java接口测试之持久层框架Spring-data-jpa

    引言 在接口测试中把 Case存储至数据库中,是比较常见的“数据驱动”做法。而在实际的接口测试用例开发中,对数据库的操作无非就是“增删改查”。...spring data jpa让我们解脱了DAO层的操作,基本上所有CRUD都可以依赖于它来实现 Spring-data-jpa使用 基本查询 基本查询分为两种: spring data默认已经实现 根据查询的方法来自动解析成...SQL 预先生成方法 Spring-data-jpa 默认预先生成了一些基本的CURD的方法,例如:增、删、改等等 /** * 继承JpaRepository,实现与数据库交互(JPA支持自动生成一些基本...多数据源的支持 同源数据库的多源支持 日常接口测试中因为测试项目使用的分布式开发模式,不同的服务有不同的数据源,常常需要在一个项目中使用多个数据源,因此需要配置 Spring-data-jpa对多数据源的使用...(如使用嵌入式数据库则不需要) 自动创建表结构的设置 例如使用mysql的情况如下: spring: profiles: active: a datasource: driver-class-name

    2.9K20

    Spring Boot(五):Spring Boot Jpa 的使用

    在上篇文章《Spring Boot(二):Web 综合开发》中简单介绍了一下 Spring Boot Jpa 的基础性使用,这篇文章将更加全面的介绍 Spring Boot Jpa 常见用法以及注意事项...学习并使用 Spring Data Jpa 可以极大提高开发效率!...1) 复杂查询 在实际的开发中我们需要用到分页、删选、连表等查询的时候就需要特殊的方法或者自定义 SQL 分页查询 分页查询在实际使用中非常普遍了,Spring Boot Jpa 已经帮我们实现了分页的功能...SQL查询 其实 Spring Data 觉大部分的 SQL 都可以根据方法名定义的方式来实现,但是由于某些原因我们想使用自定义的 SQL 来查询,Spring Data 也是完美支持的;在 SQL 的查询方法上面使用...(basePackages = "com.neo.repositories.mongo") interface Configuration { } 其它 使用枚举 使用枚举的时候,我们希望数据库中存储的是枚举对应的

    3.8K10

    SpringBoot整合Mybatis,你真的了解原理吗?

    再通俗一点: Spring Data旨在统一和简化对数据库访问的操作,而不拘泥于是关系型数据库还是NoSQL数据存储。...从上图,我们可以发现SpringData是更高层次的抽象,涵盖了数据库操作的方方面面,它具备的特性如下所示: 特性 强大的存储库和自定义对象映射抽象 从存储库方法名称派生动态查询 实现域基类提供基本属性...Spring Data JPA Spring Data JPA是更大的Spring数据家族的一部分,它使实现基于JPA的存储库变得更容易。本模块处理对基于JPA的数据访问层的增强支持。...另一种是以Java实体类为核心,将实体类的和数据库表之间建立映射关系,也就是我们说的ORM框架,如:Hibernate、Spring Data JPA。...下面我们创建一个user表,分别使用Spring Data JDBC和Mybatis来访问MySQL数据库。

    94440

    Spring Boot中使用PostgreSQL数据库

    而今天我们将介绍另外一个开源关系型数据库:PostgreSQL,以及在Spring Boot中如何使用。...PostgreSQL数据库提供RESTful API的服务 支持树状结构,可以更方便的处理具备此类特性的数据存储 外部数据源支持,可以把MySQL、Oracle、CSV、Hadoop等当成自己数据库中的表来进行查询...时间精度更高,可以精确到秒以下 字符支持更好,MySQL里需要utf8mb4才能显示emoji,PostgreSQL没这个坑 存储方式支持更大的数据量,PostgreSQL主表采用堆表存放,MySQL采用索引组织表...序列支持更好,MySQL不支持多个表从同一个序列中取id,而PostgreSQL可以 增加列更简单,MySQL表增加列,基本上是重建表和索引,会花很长时间。...其实真正变动的部分主要是两个地方: 数据库驱动的依赖 数据源的配置信息 而对于更为上层的数据操作,其实并没有太大的变化,尤其是当使用Spring Data JPA的时候,这就是抽象的魅力所在!

    6.1K50

    Spring Boot2 系列教程(三十一)Spring Boot 构建 RESTful 风格应用

    接下来的五行配置了 JPA 的基本信息,分别表示生成 SQL 的方言、打印出生成的 SQL 、每次启动项目时根据实际情况选择是否更新表、数据库平台是 MySQL。...分页数据中: size 表示每页查询记录数 totalElements 表示总记录数 totalPages 表示总页数 number 表示当前页数,从0开始计 如果要分页或者排序查询,可以使用 _links...开发者可以根据实际情况,在 BookRepository 中定义任意多个查询方法,查询方法的定义规则和 Jpa 中一模一样(不懂 Jpa 的小伙伴,可以参考干货|一文读懂 Spring Data Jpa...但是,这样有一个缺陷,就是 Jpa 中方法名太长,因此,如果不想使用方法名作为接口名,则可以自定义接口名: public interface BookRepository extends JpaRepository...如果不想暴露官方定义好的方法,例如根据 id 删除数据,只需要在自定义接口中重写该方法,然后在该方法上加 @RestResource 注解并且配置相关属性即可。

    1.3K10

    Spring Data JPA系列2:快速在SpringBoot项目中熟练使用JPA

    那么,如果你已经决定使用Spring Data JPA来作为项目中DB操作的框架,具体应该如何去做呢?...业务层执行DB操作 写入数据 SpringData JPA写操作逻辑很简单,只有一个save方法即可,如果批量写入操作,使用saveAll方法即可。...,可见数据已经写入DB中: Department表 User表 从上面可以看出,代码里面其实并没有对create_time和update_time字段进行赋值,但是数据存储到DB的时候,这两个字段被自动赋值了...---- 补充 Spring Data JPA作为Spring Data中对于关系型数据库支持的一种框架技术,属于ORM的一种,通过得当的使用,可以大大简化开发过程中对于数据操作的复杂度。...快速上手 —— 《SpringBoot集成JPA介绍》 深度进阶 —— 《JPA核心类型与用法介绍》 可靠保障 —— 《聊一聊数据库的事务,以及Spring体系下对事务的使用》 周边扩展 —— 《JPA

    2.3K40
    领券