Project Icon

spring-data-jpa

简化数据访问层开发的强大工具

Spring Data JPA是一个开源项目,旨在简化基于JPA的数据访问层开发。它提供自动化的CRUD操作、动态查询生成和审计功能,减少样板代码。开发者通过定义接口和自定义查询方法,即可获得Spring自动生成的实现,提高了数据访问层的开发效率。

= Spring Data JPA image:https://jenkins.spring.io/buildStatus/icon?job=spring-data-jpa%2Fmain&subject=Build[link=https://jenkins.spring.io/view/SpringData/job/spring-data-jpa/] https://gitter.im/spring-projects/spring-data[image:https://badges.gitter.im/spring-projects/spring-data.svg[Gitter]] image:https://img.shields.io/badge/Revved%20up%20by-Develocity-06A0CE?logo=Gradle&labelColor=02303A["由Develocity提升", link="https://ge.spring.io/scans?search.rootProjectNames=Spring Data JPA Parent"]

Spring Data JPA 是大型 https://projects.spring.io/spring-data[Spring Data] 家族的一部分,它使实现基于JPA的存储库变得简单。 这个模块处理对基于JPA的数据访问层的增强支持。 它使构建使用数据访问技术的Spring驱动应用程序变得更加容易。

长期以来,实现应用程序的数据访问层一直是一项繁琐的工作。 执行简单查询以及执行分页和审计需要编写太多样板代码。 Spring Data JPA旨在通过将工作量减少到实际需要的程度来显著改善数据访问层的实现。 作为开发人员,你只需编写存储库接口,包括自定义查找方法,Spring将自动提供实现。

== 特性

  • 为JPA实体实现CRUD方法
  • 从查询方法名动态生成查询
  • 通过查询方法透明触发JPA命名查询
  • 实现提供基本属性的域基类
  • 支持透明审计(创建、最后更改)
  • 可集成自定义存储库代码
  • 通过自定义命名空间轻松实现Spring集成

== 行为准则

本项目遵循 https://github.com/spring-projects/.github/blob/e3cc2ff230d8f1dca06535aa6b5a4a23815861d4/CODE_OF_CONDUCT.md[Spring行为准则]。参与时,你应遵守此行为准则。请将不可接受的行为报告给spring-code-of-conduct@pivotal.io。

== 入门

以下是使用Java中Spring Data存储库的应用程序的快速示例:

[source,java]

public interface PersonRepository extends CrudRepository<Person, Long> {

List findByLastname(String lastname);

List findByFirstnameLike(String firstname); }

@Service public class MyService {

private final PersonRepository repository;

public MyService(PersonRepository repository) { this.repository = repository; }

public void doWork() {

repository.deleteAll();

Person person = new Person();
person.setFirstname("Oliver");
person.setLastname("Gierke");
repository.save(person);

List<Person> lastNameResults = repository.findByLastname("Gierke");
List<Person> firstNameResults = repository.findByFirstnameLike("Oli%");

} }

@Configuration @EnableJpaRepositories("com.acme.repositories") class AppConfig {

@Bean public DataSource dataSource() { return new EmbeddedDatabaseBuilder().setType(EmbeddedDatabaseType.H2).build(); }

@Bean public JpaTransactionManager transactionManager(EntityManagerFactory emf) { return new JpaTransactionManager(emf); }

@Bean public JpaVendorAdapter jpaVendorAdapter() { HibernateJpaVendorAdapter jpaVendorAdapter = new HibernateJpaVendorAdapter(); jpaVendorAdapter.setDatabase(Database.H2); jpaVendorAdapter.setGenerateDdl(true); return jpaVendorAdapter; }

@Bean public LocalContainerEntityManagerFactoryBean entityManagerFactory() { LocalContainerEntityManagerFactoryBean lemfb = new LocalContainerEntityManagerFactoryBean(); lemfb.setDataSource(dataSource()); lemfb.setJpaVendorAdapter(jpaVendorAdapter()); lemfb.setPackagesToScan("com.acme"); return lemfb; } }

=== Maven配置

添加Maven依赖:

[source,xml]

org.springframework.data spring-data-jpa ${version} ----

如果你更喜欢即将发布的主要版本的最新快照,请使用我们的Maven快照仓库并声明适当的依赖版本。

[source,xml]

org.springframework.data spring-data-jpa ${version}-SNAPSHOT spring-snapshot Spring快照仓库 https://repo.spring.io/snapshot ----

== 获取帮助

使用Spring Data遇到问题?我们很乐意帮助!

== 报告问题

Spring Data使用GitHub作为问题跟踪系统来记录错误和功能请求。如果你想提出问题,请遵循以下建议:

== 从源代码构建

你不需要从源代码构建来使用Spring Data(二进制文件在 https://repo.spring.io[repo.spring.io]),但如果你想尝试最新最好的版本,Spring Data可以使用 https://github.com/takari/maven-wrapper[maven wrapper] 轻松构建。 你还需要JDK 17或更高版本。

[source,bash]

$ ./mvnw clean install

如果你想使用常规的mvn命令进行构建,你需要 https://maven.apache.org/run-maven/index.html[Maven v3.8.0或更高版本]。

另请参阅 link:CONTRIBUTING.adoc[CONTRIBUTING.adoc],如果你希望提交拉取请求,特别是在进行第一个非微不足道的更改之前,请签署 https://cla.pivotal.io/sign/spring[贡献者协议]。

=== 构建参考文档

构建文档也会构建项目,但不运行测试。

[source,bash]

$ ./mvnw clean install -Pantora

生成的文档可在target/antora/site/index.html中获取。

== 指南

https://spring.io/[spring.io] 网站包含几个指南,展示了如何一步步使用Spring Data:

== 示例

== 许可证

Spring Data JPA是根据 https://www.apache.org/licenses/LICENSE-2.0.html[Apache 2.0许可证] 发布的开源软件。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号