使用JPA的步骤:
-
创建表基础类(pojo),在类中标注 @Entity 以及 @id ,并引入包import javax.persistence.* (引入该包的目的在于使用@Entity和@id注解)
-
创建Dao层。创建一个dao接口,该接口继承 JpaRepository<基础类,主键对象> 注意:继承的类中泛型中第一个对象,是持久化基础类,一般该类与数据库中的表名一致(也可以使用@Table(name=“数据库表名”)指明对应的表名),泛型中第二个类型参数表示是表基础类的主键id,可以是String、一个对象等。
-
在接口中编写第一个持久化方法。基本格式:
@query(value = “select p from user p where p.id = ?1”)
User selectUserById(String id); -
接下来就可以测试了。
注意事项:
-
表实体类采用驼峰命名时,在执行sql时会自动将驼峰命名转换成带有下划线的表名。注意在开发时要根据表名进行分析判断采用什么方式命名表实体类。
-
在使用Jpa规范中内置的delete、save等操作数据的方法时,表实体类的命名一定要注意分析是否采用驼峰命名法。数据库中带有下划线的表必须要使用驼峰命名,不带有下划线的不可以使用驼峰命名,可以使用首字母大写,其余小写的命名方式。
-
在@query注解中的表名要与表实体类名称保持一直,并且表实体类中关于查询sql的表名也要与表实体类名称一致。
-
@query注解中的nativeQuery属性为true表示,直接复制value值在数据库执行,false表示通过框架处理后在数据库执行。
-
在JPA的代码中,如果使用自定义Update、delete语句时,要使用@Modifying(修改查询注解)注解,例如:
-
jpa 在写Query( value = “ sql ") 时,写sql 语句要加上别名,否则容易出错,应该这样写 : select a from user a where a.name = ?1 and a.username = ?2
-
jpa与Hibernate的关系:总的来说,JPA是规范,Hibernate是框架,JPA是持久化规范,而Hibernate实现了JPA。