首页 > 其他分享 >使用JPA持久化

使用JPA持久化

时间:2024-03-21 19:02:35浏览次数:24  
标签:实体类 持久 驼峰 JPA 使用 表名 命名 id

使用JPA的步骤:

  1. 创建表基础类(pojo),在类中标注 @Entity 以及 @id ,并引入包import javax.persistence.* (引入该包的目的在于使用@Entity和@id注解)

  2. 创建Dao层。创建一个dao接口,该接口继承 JpaRepository<基础类,主键对象> 注意:继承的类中泛型中第一个对象,是持久化基础类,一般该类与数据库中的表名一致(也可以使用@Table(name=“数据库表名”)指明对应的表名),泛型中第二个类型参数表示是表基础类的主键id,可以是String、一个对象等。

  3. 在接口中编写第一个持久化方法。基本格式:
    @query(value = “select p from user p where p.id = ?1”)
    User selectUserById(String id);

  4. 接下来就可以测试了。

注意事项:

  1. 表实体类采用驼峰命名时,在执行sql时会自动将驼峰命名转换成带有下划线的表名。注意在开发时要根据表名进行分析判断采用什么方式命名表实体类。

  2. 在使用Jpa规范中内置的delete、save等操作数据的方法时,表实体类的命名一定要注意分析是否采用驼峰命名法。数据库中带有下划线的表必须要使用驼峰命名,不带有下划线的不可以使用驼峰命名,可以使用首字母大写,其余小写的命名方式。

  3. 在@query注解中的表名要与表实体类名称保持一直,并且表实体类中关于查询sql的表名也要与表实体类名称一致。

  4. @query注解中的nativeQuery属性为true表示,直接复制value值在数据库执行,false表示通过框架处理后在数据库执行。

  5. 在JPA的代码中,如果使用自定义Update、delete语句时,要使用@Modifying(修改查询注解)注解,例如:
    在这里插入图片描述

  6. jpa 在写Query( value = “ sql ") 时,写sql 语句要加上别名,否则容易出错,应该这样写 : select a from user a where a.name = ?1 and a.username = ?2

  7. jpa与Hibernate的关系:总的来说,JPA是规范,Hibernate是框架,JPA是持久化规范,而Hibernate实现了JPA。

标签:实体类,持久,驼峰,JPA,使用,表名,命名,id
From: https://blog.csdn.net/qq_44031124/article/details/136915180

相关文章

  • 使用JMeter从JSON响应的URL参数中提取特定值
    在使用ApacheJMeter进行API测试时,我们经常需要从JSON格式的响应中提取特定字段的值。这可以通过使用JMeter内置的JSON提取器和正则表达式提取器来完成。以下是一个具体的例子,展示了如何从一个JSON响应中提取rowId的值,同时处理字符串终止符。假设我们有以下JSON响应:{"flag":......
  • nmon监控工具使用方法详解
    在信息化时代,系统监控对于确保服务器和应用的稳定运行至关重要。nmon(Nigel’sMonitor)作为一款强大的性能监控工具,以其直观、全面的监控能力,赢得了众多系统管理员的青睐。本文将详细介绍nmon监控工具的使用方法,帮助读者更好地利用这一工具,提升系统监控效率。一、nmon监控工......
  • PGSQL COPY 命令的使用
    ddd根据大佬的测试 https://developer.aliyun.com/ask/54534,copy命令的效率是很高的。但copy命令只能操作本机的文件,所以浏览器上传的文件需要通过共享文件夹上传部署PGSQL服务器(测试IP为:192.168.1.11)中。//Uploadentirefile   UploadWholeFile.ashx......
  • Java使用注解@Scheduled开启定时任务
    @Scheduled(cron="[秒][分][小时][日][月][周][年]")说明:多个并列的时间以英文逗号“,”隔开。比如:@Scheduled(cron="053,55161**")上面意思是:1号的下午16:53,16:55执行二次。 @Scheduled(cron="0/10****?")每隔10秒运行一次。 @Scheduled(c......
  • golang使用redis锁(避免误解锁/死锁/过期引起并发):go-redis, redigo
    【go-redis】简单实现方式,不会死锁/误解锁packagemainimport("context""fmt""sync""time"redis2"github.com/redis/go-redis/v9")varmutexsync.Mutex//redis加锁sec:锁定秒数(避免死锁),value锁唯一值(避免误解......
  • 数据清洗使用Parallel 多线程
    一.概述在开发数据清洗时,ES数据集有600w条,每一条的子对象又有几十条,需要拿到子对象去重后的集合,使用分批提取ES数据,共535批。开始使用List来操作,关键代码如下:varspecListAll=newList<SpecInfo>();for(inti=0;i<batchCount;i++)......
  • ROS git使用
    ROSgit使用基本流程创建ROS项目和初始化Git仓库这里是使用Git和VisualStudioCode(VSCode)来管理一个ROS项目的完整指南,包括创建项目、初始化Git仓库、更改本地默认分支为main,以及将代码推送到远程仓库的步骤:创建ROS项目创建工作空间:mkdir-p~/r......
  • 大模型应用开发:手把手教你部署并使用清华智谱GLM大模型
    部署一个自己的大模型,没事的时候玩两下,这可能是很多技术同学想做但又迟迟没下手的事情,没下手的原因很可能是成本太高,近万元的RTX3090显卡,想想都肉疼,又或者官方的部署说明过于简单,安装的时候总是遇到各种奇奇怪怪的问题,难以解决。本文就来分享下我的安装部署经验,包括本地和租用......
  • requests.post传的data如果是直接使用python dict封装,有些服务端接收不了这种数据类型
    平时在自己的php项目里,使用dict方式组装data,然后requests.post,一点问题都没有。但是调了后端一个java的微服务接口,结果就一直报错422: 最后问了一下开发,得到提示“python好像还有个毛病,python的json对象转字符串的时候,转出来的字符串不是标准json字符串,还要做个字符串处理,变成......
  • OKR与KPI(关键绩效指标)有何不同?如何结合使用?
    在现代企业管理中,绩效考核是确保组织目标得以实现的重要手段。其中,OKR(ObjectivesandKeyResults,目标与关键成果)和KPI(KeyPerformanceIndicators,关键绩效指标)是两种常用的绩效管理工具。虽然它们都是为了提升组织绩效而设计的,但在理念、操作方式和应用场景上却存在着明显的不同......