首頁 > 軟體

Java之jpa入門教學講解

2021-08-10 22:00:02

JPA快速入門介紹

一:什麼是JPA

JPA的英文全稱是Java PersistenceAPI, 目的是給Java開發者提供物件關係對映工具用於在

Java應用程式開發中來管理關係資料(RDBMS)。JavaPersistence 包含下面三個部分:

  1. Java持久化API
  2. JPA查詢語言
  3. 物件關係對映後設資料

二:JPA有哪些框架提供了的實現

當前JPA提供廠商有Hibernate, Apache, Eclipse Link等,Google雲端計算平臺 AppEngine也使

用了JPA作為持久層。JPA作為持久層框架有如下優點:

  1. 簡單易用,幫助開發者提供了生產率
  2. 便於維護,減低了維護成本
  3. 學習成本相對比較低。

但是JPA的缺點也是顯而易見,JPA作為持久層有如下缺點:

  1. 將語言與資料庫混在一起,導致資料改動以後,組態檔必須更新
  2. 對與多資料與巨量資料量處理很容易產生效能問題。
  3. 過度封裝,導致錯誤查詢相對與JDBC等傳統開發技術而言更加困難

三:標準的JPA規範JSR粗略解讀

JPA的最新規範為JSR Java PersistenceAPI Version 2.0

Entity Class – 實體類,必須使用註解@entity標明,同時必須有一個無引數的建構函式,而

且無引數建構函式必須為public或者protected,如果一個entity class被標記為final將導致

出錯。

EntityManager – 實體管理者,管理Entity範例的整個生命週期,而且使用Query API來查詢

實體與他們的persist狀態。

Query Language – 基於字串的查詢語句,用來查詢實體(Entity)與他們的狀態。

MetaModel API – 通過EntityManagerFactory或者EntityManager的getMetamodel()方法獲取,

檢視persistence-unit的資訊。

實體管理者與持久化上下文(Entity Manager and Persistence contexts)

Persistence Contexts – 一個被管理的實體的範例集合,在一個持久化上下文中的所有範例都

由Entity Manager來管理它們整個生命週期。

持久化單元(Persistence-Unit) – 一個持久化單元是個邏輯分組包括以下部分:

  • 一個實體管理者工廠及它的實體管理者
  • 被管理的class集合,在persistence unit組態檔中定義
  • 對映後設資料– 註解定義或者xml定義匹配的類      
  • ORM後設資料(MetaData forObject/Relational Mapping) – 坦白的說就annotation的各種解釋與使用。

詳細瞭解請閱讀Oracle官方檔案 - 《persistence-2_0-final-spec》PDF檔案。

四:JPA簡單範例說明

1.      使用ObjectDB作為資料庫,關於ObjectDB請參考http://www.objectdb.com/

2.      參考了objectDB的例子,程式碼幾乎沒有改動,檔案說明參見這裡:

http://www.objectdb.com/tutorial/jpa/eclipse/web

3.      一個可執行的JPA範例原始碼:

entity class:

package com.gloomyfish.jpa.tutorial;

import java.io.Serializable;
import javax.persistence.*;

@Entity
public class Point implements Serializable {
    private static final long serialVersionUID = 1L;

    @Id @GeneratedValue
    private long id;

    private int x;
    private int y;

    public Point() {
    }

    Point(int x, int y) {
        this.x = x;
        this.y = y;
    }

    public Long getId() {
        return id;
    }

    public int getX() {
         return x;
    }

    public int getY() {
         return y;
    }

    @Override
    public String toString() {
        return String.format("(%d, %d)", this.x, this.y);
    }
}

Main Test JPA;

package com.gloomyfish.jpa.tutorial;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import javax.persistence.TypedQuery;

public class JPAMain {
    public static void main(String[] args) {
        // Open a database connection
        // (create a new database if it doesn't exist yet):
        EntityManagerFactory emf =
            Persistence.createEntityManagerFactory("$objectdb/db/points.odb");
        EntityManager em = emf.createEntityManager();

        // Store 1000 Point objects in the database:
        long startTime = System.currentTimeMillis();
        em.getTransaction().begin();
        for (int i = 0; i < 10; i++) {
            Point p = new Point(i, i);
            em.persist(p);
        }
        em.getTransaction().commit();
        long endTime = System.currentTimeMillis();
        System.out.println("save time = " + (endTime - startTime));
        // Find the number of Point objects in the database:
        Query q1 = em.createQuery("SELECT COUNT(p) FROM Point p");
        System.out.println("Total Points: " + q1.getSingleResult());

        // Find the average X value:
        Query q2 = em.createQuery("SELECT AVG(p.x) FROM Point p");
        System.out.println("Average X: " + q2.getSingleResult());

        // Retrieve all the Point objects from the database:
        TypedQuery<Point> query =
            em.createQuery("SELECT p FROM Point p", Point.class);
        List<Point> results = query.getResultList();
        for (Point p : results) {
            System.out.println(p);
        }

        // Close the database connection:
        em.close();
        emf.close();
    }
}

到此這篇關於Java之jpa入門教學講解的文章就介紹到這了,更多相關Java之jpa內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com