欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java之jpa入門(mén)教程講解

 更新時(shí)間:2021年08月10日 16:58:35   作者:openkk  
這篇文章主要介紹了Java之jpa入門(mén)教程講解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

JPA快速入門(mén)介紹

一:什么是JPA

JPA的英文全稱(chēng)是Java PersistenceAPI, 目的是給Java開(kāi)發(fā)者提供對(duì)象關(guān)系映射工具用于在

Java應(yīng)用程序開(kāi)發(fā)中來(lái)管理關(guān)系數(shù)據(jù)(RDBMS)。JavaPersistence 包含下面三個(gè)部分:

  1. Java持久化API
  2. JPA查詢(xún)語(yǔ)言
  3. 對(duì)象關(guān)系映射元數(shù)據(jù)

二:JPA有哪些框架提供了的實(shí)現(xiàn)

當(dāng)前JPA提供廠商有Hibernate, Apache, Eclipse Link等,Google云計(jì)算平臺(tái) AppEngine也使

用了JPA作為持久層。JPA作為持久層框架有如下優(yōu)點(diǎn):

  1. 簡(jiǎn)單易用,幫助開(kāi)發(fā)者提供了生產(chǎn)率
  2. 便于維護(hù),減低了維護(hù)成本
  3. 學(xué)習(xí)成本相對(duì)比較低。

但是JPA的缺點(diǎn)也是顯而易見(jiàn),JPA作為持久層有如下缺點(diǎn):

  1. 將語(yǔ)言與數(shù)據(jù)庫(kù)混在一起,導(dǎo)致數(shù)據(jù)改動(dòng)以后,配置文件必須更新
  2. 對(duì)與多數(shù)據(jù)與大數(shù)據(jù)量處理很容易產(chǎn)生性能問(wèn)題。
  3. 過(guò)度封裝,導(dǎo)致錯(cuò)誤查找相對(duì)與JDBC等傳統(tǒng)開(kāi)發(fā)技術(shù)而言更加困難

三:標(biāo)準(zhǔn)的JPA規(guī)范JSR粗略解讀

JPA的最新規(guī)范為JSR Java PersistenceAPI Version 2.0

Entity Class – 實(shí)體類(lèi),必須使用注解@entity標(biāo)明,同時(shí)必須有一個(gè)無(wú)參數(shù)的構(gòu)造函數(shù),而

且無(wú)參數(shù)構(gòu)造函數(shù)必須為public或者protected,如果一個(gè)entity class被標(biāo)記為final將導(dǎo)致

出錯(cuò)。

EntityManager – 實(shí)體管理者,管理Entity實(shí)例的整個(gè)生命周期,而且使用Query API來(lái)查詢(xún)

實(shí)體與他們的persist狀態(tài)。

Query Language – 基于字符串的查詢(xún)語(yǔ)句,用來(lái)查詢(xún)實(shí)體(Entity)與他們的狀態(tài)。

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

查看persistence-unit的信息。

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

Persistence Contexts – 一個(gè)被管理的實(shí)體的實(shí)例集合,在一個(gè)持久化上下文中的所有實(shí)例都

由Entity Manager來(lái)管理它們整個(gè)生命周期。

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

  • 一個(gè)實(shí)體管理者工廠及它的實(shí)體管理者
  • 被管理的class集合,在persistence unit配置文件中定義
  • 映射元數(shù)據(jù)– 注解定義或者xml定義匹配的類(lèi)      
  • ORM元數(shù)據(jù)(MetaData forObject/Relational Mapping) – 坦白的說(shuō)就annotation的各種解釋與使用。

詳細(xì)了解請(qǐng)閱讀Oracle官方文檔 - 《persistence-2_0-final-spec》PDF文檔。

四:JPA簡(jiǎn)單實(shí)例說(shuō)明

1.      使用ObjectDB作為數(shù)據(jù)庫(kù),關(guān)于ObjectDB請(qǐng)參考http://www.objectdb.com/

2.      參考了objectDB的例子,代碼幾乎沒(méi)有改動(dòng),文檔說(shuō)明參見(jiàn)這里:

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

3.      一個(gè)可運(yùn)行的JPA實(shí)例源代碼:

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();
    }
}

到此這篇關(guān)于Java之jpa入門(mén)教程講解的文章就介紹到這了,更多相關(guān)Java之jpa內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論