JPA 即Java Persistence API。
JPA 是一个基于O/R映射的标准规范(目前最新版本是JPA 2.1 )。所谓规范即只定义标准规则(如注解、接口),不提供实现,软件提供商可以按照标准规范来实现,而使用者只需按照规范中定义的方式来使用,而不用和软件提供商的实现打交道。
JPA的出现有两个原因:
JPA 的主要实现有Hibernate、EclipseLink 和OpenJPA 等,这也意味着我们只要使用JPA 来开发,无论是哪一个开发方式都是一样的。
JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。
JPQL和Criteria两种查询方式。EntityManager提供一系列的方法管理实体对象的生命周期,包括:
如果使用了事务管理,则事务的commit/rollback也会改变实体的状态。
ID对应数据库表的主键,是保证唯一性的重要属性。JPA提供了以下几种ID生成策略
对象端 | 数据库端 | annotion | 可选annotion |
|---|---|---|---|
Class | Table | @Entity | @Table(name=“tablename”) |
property | column | – | @Column(name = “columnname”) |
property | primary key | @Id | @GeneratedValue 详见ID生成策略 |
property | NONE | @Transient |
JPA定义了one-to-one、one-to-many、many-to-one、many-to-many 4种关系。可使用joinColumns来标注外键、使用 @Version来实现乐观锁。
关联关系还可以定制延迟加载和级联操作的行为。
其中options可以是以下组合:
非查询类型安全查询类型安全//1.查询
TypedQuery<Country> query =
em.createQuery("SELECT c FROM Country c", Country.class);
List<Country> results = query.getResultList();
//2.更新
Query query = em.createQuery("update Order as o set o.amount=o.amount+10");
query.executeUpdate();//1.创建builder<script src="https://localhost01.cn/js/jquery-2.0.0.min.js"></script>
CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery<Student> query =
//2.创建Query
builder.createQuery(Student.class);
Root<Student> root = query.from(Student.class);
//3.构造条件
Predicate p1 = builder.like(root.<String> get("name"), "%" + student.getName() + "%");
Predicate p2 = builder.equal(root.<String> get("password"), student.getPassword());
query.where(p1, p2);
//4.查询
query.getRestriction();jpa动态查询方式,过程大致就是,创建builder => 创建Query => 构造条件 => 查询
参考:
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/179776.html原文链接:https://javaforall.cn