深入探索 Java JPA 的核心概念:实体、映射和查询

2024年 2月 20日 36.2k 0

深入探索 java jpa 的核心概念:实体、映射和查询

实体

php小编苹果在本文中将带您深入探索Java JPA的核心概念:实体、映射和查询。随着现代应用程序的复杂性增加,对JPA的理解变得至关重要。本文将帮助您理解JPA中的关键概念,以便更好地应用于实际项目中。

@Entity
public class Person {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

private String name;

private int age;

// 省略 getter 和 setter 方法
}

登录后复制

映射

映射是 JPA 用于将实体类中的属性与数据库中的字段相对应的机制。JPA 提供了许多类型的映射,包括:

  • 一对一映射:一个实体类中的一个属性对应数据库表中的一列。
  • 一对多映射:一个实体类中的一个属性对应数据库表中的多列。
  • 多对一映射:一个实体类中的多个属性对应数据库表中的一列。
  • 多对多映射:一个实体类中的多个属性对应数据库表中的多列。

映射还可以指定属性的类型、长度、是否允许为空等信息。

@Entity
public class Person {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@Column(length = 50, nullable = false)
private String name;

@Column(nullable = false)
private int age;

// 省略 getter 和 setter 方法
}

登录后复制

查询

JPA 提供了多种查询机制,包括:

  • JPQL(Java Persistence Query Language):一种类似于 sql 的查询语言,可以用于查询实体对象。
  • Criteria api:一种面向对象的查询 API,可以用于查询实体对象。
  • 本机查询:使用原生 SQL 查询数据库。

// JPQL 查询
List persons = entityManager.createQuery("SELECT p FROM Person p WHERE p.age > 18", Person.class)
.getResultList();

// Criteria API 查询
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
CriteriaQuery cq = cb.createQuery(Person.class);
Root root = cq.from(Person.class);
cq.select(root).where(cb.gt(root.get("age"), 18));
List persons = entityManager.createQuery(cq).getResultList();

// 本机查询
List persons = entityManager.createNativeQuery("SELECT * FROM Person WHERE age > 18", Person.class)
.getResultList();

登录后复制

总结

JPA 是一个功能强大的持久化框架,它提供了对关系数据库的统一访问。通过使用 JPA,我们可以轻松地将 Java 对象持久化到数据库中,并使用 JPQL、Criteria API 或本机查询来查询实体对象。

以上就是深入探索 Java JPA 的核心概念:实体、映射和查询的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论