使用JPA持久化

使用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。

  • 25
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值