使用JPA自动生成代码(轻松上手看了就会版)

简介: 使用JPA自动生成代码(轻松上手看了就会版)

背景:

项目需要自动生成sql代码,不需要写sql语句,能够自动进行查询,我想到了JPA。

方案

概念:

JPA 的全称是 Java Persistence API,是 Java EE 规范之一,用于定义 Java 对象与关系型数据库之间的映射关系。JPA 提供了一种简单的方式,让开发者可以通过面向对象的方式来操作数据库,而不需要手动编写 SQL 语句。

JPA 的主要作用

1、将 Java 对象映射到关系型数据库中的表格。

2、提供了一种统一的 API,可以让开发者以面向对象的方式来操作数据库,而不需要关心底层的数据库操作细节。

3、支持事务处理、缓存管理等高级功能。

4、提供了查询语言 JPQL,可以以面向对象的方式编写查询语句。

JPA 是 Java EE 规范的一部分,不是一个具体的实现。常见的 JPA 实现包括 Hibernate、EclipseLink、OpenJPA 等。在使用 JPA 进行开发时,可以选择一个符合自己需求的 JPA 实现,并按照 JPA 的规范进行开发。

jpa简单使用(Springboot项目)

@Repository
public interface ContentGrainDao extends JpaRepository<ContentGrain, Long> {
}
@SpringBootApplication
public class PushClassApplication implements CommandLineRunner {
    @Autowired
    ContentGrainDao contentGrainRepository;
    @Autowired
    private UserOrderRepository userOrderRepository;
    public static void main(String[] args) {
        SpringApplication.run(PushClassApplication.class,args);
    }
    @Override
    public void run(String... args) throws Exception {
//将断点打到这里
        List<ContentGrain> result = contentGrainRepository.findAll();
        System.out.println("222");
}
}

jpa进阶使用

//AcademyEntity 是要查表的实体,Long是这张表的主键类型
public interface TTAcademyDao  extends JpaRepository<AcademyEntity, Long> 
{
    AcademyEntity findByNameAndIsDelete(String name, int isDelete);
}

JPA 的命名规范是基于方法名称自动生成 SQL 查询语句,方法名称必须遵循一定的规范,以便自动生成正确的 SQL 语句。

根据 JPA 命名规范,findByNameAndIsDelete 这个方法名表示按照 name 和 isDelete 属性进行查询。具体解释如下:

find:表示这是一个查询方法。

By:表示按照某个属性进行查询。

Name:表示按照 name 属性进行查询。

And:表示并且关系,即同时满足两个条件。

IsDelete:表示按照 isDelete 属性进行查询。

根据这个方法名称,JPA 可以自动生成类似下面的 SQL 查询语句:

SELECT * FROM AcademyEntity WHERE name = ? AND is_delete = ?

这样就可以通过方法名称来实现简单的查询操作,而不需要手动编写 SQL 查询语句。需要注意的是,JPA 命名规范有一定的限制,不支持所有的查询语句,一些复杂的查询仍然需要手动编写 SQL 语句(个人认为没有必要,要是需要使用sql的话,就不用JPA了)。

总结

善假于物实现自动化~

JPA(Java Persistence API)是Java平台上的一种ORM(对象关系映射)规范,它提供了一种简化数据库操作的方法,将Java对象与数据库表之间的映射关系交给JPA来管理。使用JPA带来了许多好处,其中一些主要的好处如下:

简化数据库操作:JPA封装了许多常见的数据库操作,如插入、更新、删除和查询等,使得数据库访问变得更加简洁和易于理解。通过JPA,开发人员可以使用面向对象的方式来操作数据库,而不需要编写复杂的SQL语句。

提高生产效率:使用JPA可以大大减少开发人员的工作量,因为不再需要手动编写大量的SQL语句和数据库访问代码。JPA提供了一套自动化的持久化机制,可以将Java对象持久化到数据库中,并从数据库中检索数据,从而加快开发速度。

跨数据库支持:JPA提供了一种与数据库无关的编程方式,使得应用程序可以轻松地从一个数据库切换到另一个数据库,而不需要修改大量的代码。这种特性为应用程序的可移植性和可扩展性提供了便利。

对象关系映射:JPA通过对象关系映射将Java对象与数据库表之间建立起映射关系,使得开发人员可以更自然地使用面向对象的方式来操作数据。这种方式可以减少代码的冗余,提高代码的可维护性。

缓存支持:JPA提供了一级缓存和二级缓存的支持,可以减少数据库访问,提高应用程序的性能和响应速度。

事务管理:JPA提供了对事务的支持,可以保证在一系列数据库操作中,要么全部成功提交,要么全部失败回滚,从而确保数据库的一致性和完整性。

标准化规范:JPA是Java EE的一部分,它提供了一个标准的API,使得不同的JPA实现可以在不同的应用服务器上运行。这种标准化规范促进了开发人员之间的合作和知识共享。

总的来说,使用JPA可以简化数据库操作、提高开发效率、增加代码的可维护性,同时提供跨数据库支持和事务管理等重要功能,使得Java开发人员能够更专注于业务逻辑的实现,而不必过多关注数据库操作的细节。


目录
打赏
0
0
0
0
3
分享
相关文章
C# 10.0中Lambda表达式的改进:更简洁、更灵活的代码编写体验
【1月更文挑战第21天】随着C#语言的不断发展,Lambda表达式作为一种简洁、高效的函数式编程工具,在C# 10.0中迎来了重要的改进。本文将详细探讨C# 10.0中Lambda表达式的新特性,包括参数类型的推断增强、自然类型的Lambda参数以及Lambda表达式的属性改进等。这些改进不仅简化了Lambda表达式的编写过程,还提升了代码的可读性和灵活性,为开发者带来了更优质的编程体验。
如何利用FuncGPT告别繁琐的开源代码调试
作为一名开发人员,您是否曾经在浩如烟海的开源社区中搜索代码,然后花费大量时间测试、调试,最后才发现这些代码并不符合您的需求?专注Java生成AI函数的FuncGPT(慧函数)就像您的私人编程助手,只需输入你的需求,就能提供符合要求的函数,让你告别繁琐的搜索、测试和调试,迈向高效的开发之旅。
|
4月前
|
C#一分钟浅谈:ReSharper 插件增强开发效率
【10月更文挑战第25天】ReSharper 是 JetBrains 开发的一款 Visual Studio 插件,旨在提高 .NET 开发者的生产力。它通过代码分析、重构、导航等功能,帮助开发者避免常见错误,提升代码质量和开发效率。本文将通过具体代码案例,详细介绍 ReSharper 的常见功能及其应用。
89 1
Python作为一种简洁、易读且功能强大的编程语言,其自动化测试和单元测试框架的丰富性和易用性为开发者提供了极大的便利
【6月更文挑战第10天】本文探讨了Python自动化测试与单元测试框架在提升代码质量和效率中的作用。Selenium、Appium和pytest是常用的自动化测试框架,分别支持Web和移动应用的测试。unittest是Python的标准单元测试框架,提供断言方法和测试组织结构。通过制定测试计划、编写高质量测试用例、持续集成与测试、以及有效利用测试报告,开发者能提高代码质量和开发效率。
60 1
代码生成工具:提升开发效率的利器
随着技术的不断进步,以及在AI浪潮的推动下,代码生成工具逐渐成为开发者们提高效率的得力助手,代码生成工具在现代软件开发中扮演着越来越重要的角色。作为程序开发者,我觉得代码生成工具不是程序员的所有,但是它可以是程序员在开发中的“左膀右臂”,代码生成工具更多的是帮助开发者提高在日常开发中的效率。那么本文就来分享一下关于代码生成工具在开发过程中的应用情况,并对这一领域的未来发展提出些许期待和诉求。
166 7
代码生成工具:提升开发效率的利器
5款超好用的在线IDE,媲美vscode,可以直接编写前端构建化项目,而无需在本地下载依赖包,非常适合学习、demo、原型开发
5款超好用的在线IDE,媲美vscode,可以直接编写前端构建化项目,而无需在本地下载依赖包,非常适合学习、demo、原型开发
3430 0
推荐五款简洁而实用的工具,值得你尝试
分享快乐是生活中美好的瞬间,而分享简单巧妙的工具也能令我愉悦。这五款工具简洁而实用,值得你尝试。
107 0
分享5款简洁的小工具,助你轻松日常
生活中的小工具,如同隐秘的宝藏,有时能为我们的日常增添一丝轻松和趣味。以下是五款简洁而实用的工具,或许它们能为你的生活带来一些小惊喜。
119 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等