JPA规范介绍及实例(Java数据持久化解决方案)
2016-05-12 23:16
525 查看
转载请注明出处:/article/8662607.html,谢谢!
JPA(Java Persistence API)是一种Java持久化解决方案,负责把数据保存到数据库。
因其与数据库息息相关,本人将本文分类到 数据库 下。
JPA是存储业务实体关联的实体的来源。它显示了如何定义一个面向普通Java对象(POJO)作为一个实体,以及如何与管理关系实体。
在 EJB 3 之前,EJB主要包含三种类型:
会话Bean
消息驱动Bean
实体Bean
但自 EJB 3.0 开始,实体Bean被单独分离出来,形成了新的规范:JPA。所以,JPA完全可以脱离 EJB 3 来使用。
知道了JPA的由来,那么也就很清楚其实它就是一种标准、规范,而不是具体的实现(如Hibernate)。
JPA是Java官方提出的、随Java EE 5 规范一同发布的。在此之前,已经存在很多ORM框架了,他们都有不同的实现,这也是JAP出现的必然条件:
ORM框架的出现,使直接存储对象成为可能,它们将Java对象拆分成SQL语句,并利用JDBC保存到数据库。但是不同的框架,使用起来却是很大不同的,这也导致开发者需要学习各种不同的ORM框架(虽然你可能觉得精通一个ORM框架就够了,但你也不能保证不会碰到需要维护别人的程序的时候,当然,他们很可能就使用了不同的框架)。而JAP规范,正式为了解决这个问题:规范ORM框架,是ORM框架有统一的接口和用法。
至于规范,我们可以把它当作接口来理解,它规定了应该怎么做,但不包含任何实现。所以JPA并不能单独使用,必须指定实现了JPA的框架。
JAP既然已经解释清楚了,好处就很显然:程序不再依赖某个具体的ORM框架。比如:使用JPA+Hibernate的程序,简单的修改配置,即可改为JPA+TopLink,以为它们都实现了JPA规范。
Eclipselink 也是一种比较强大的ORM框架,由Oracle企业级的ORM平台TopLink代码捐献给Eclipse社区而来的。所以下面会以Eclipselink 作JPA实现来介绍。
首先创建工程:
输入项目名字,选择JDK1.7以上版本,并选择JPA版本:
继续点下一步,知道出现下面这个界面,选择使用EclipseLink库,如果没有,请点游标的小图标下载,知道可以如图勾选,然后点finish:
这时,你应该能得到如下项目结构:
按自己的习惯,新建包。
接下来编写一个实体:
这时应该会报错,因为persistence.xml文件中还没配置实体,而且其他配置信息也还没有,下面就为其添加位置,添加后完整的persistence.xml文件内容如下(为了演示输出时不会有太多内容,日志设为OFF):
很显然,上面配置的需要访问的数据库是MySQL,所以我们需要为项目添加jdbc驱动,本人使用的 mysql-connector-java-5.1.9.jar ,读者可以按自己想要的添加。
接下来就是CRUD测试方法的编写,下面将代码一并贴出(代码仅供介绍JPA,编码方式没有任何参考价值):
以下是输出结果:
但是JPA毕竟是一种重量级的,需要Jave EE 容器支持(如Jboss)。
JPA有一套标准的API,这里不多介绍,其实并没有很多人去详细了解这些。后面会介绍Spring Data JPA,也应是我们开发时框架的首选。相对传统的Spring+Hibernate,Spring Data JPA+Hibernate是一种更先进,也更方便简单的用法,相应的文章,也会在最近一两天编辑完成,完成后会在本文添加链接,欢迎大家阅读,互相学习探讨。
JPA(Java Persistence API)是一种Java持久化解决方案,负责把数据保存到数据库。
因其与数据库息息相关,本人将本文分类到 数据库 下。
概述
JPA是存储业务实体关联的实体的来源。它显示了如何定义一个面向普通Java对象(POJO)作为一个实体,以及如何与管理关系实体。在 EJB 3 之前,EJB主要包含三种类型:
会话Bean
消息驱动Bean
实体Bean
但自 EJB 3.0 开始,实体Bean被单独分离出来,形成了新的规范:JPA。所以,JPA完全可以脱离 EJB 3 来使用。
知道了JPA的由来,那么也就很清楚其实它就是一种标准、规范,而不是具体的实现(如Hibernate)。
JPA是Java官方提出的、随Java EE 5 规范一同发布的。在此之前,已经存在很多ORM框架了,他们都有不同的实现,这也是JAP出现的必然条件:
ORM框架的出现,使直接存储对象成为可能,它们将Java对象拆分成SQL语句,并利用JDBC保存到数据库。但是不同的框架,使用起来却是很大不同的,这也导致开发者需要学习各种不同的ORM框架(虽然你可能觉得精通一个ORM框架就够了,但你也不能保证不会碰到需要维护别人的程序的时候,当然,他们很可能就使用了不同的框架)。而JAP规范,正式为了解决这个问题:规范ORM框架,是ORM框架有统一的接口和用法。
至于规范,我们可以把它当作接口来理解,它规定了应该怎么做,但不包含任何实现。所以JPA并不能单独使用,必须指定实现了JPA的框架。
JAP既然已经解释清楚了,好处就很显然:程序不再依赖某个具体的ORM框架。比如:使用JPA+Hibernate的程序,简单的修改配置,即可改为JPA+TopLink,以为它们都实现了JPA规范。
实例
Eclipselink 也是一种比较强大的ORM框架,由Oracle企业级的ORM平台TopLink代码捐献给Eclipse社区而来的。所以下面会以Eclipselink 作JPA实现来介绍。首先创建工程:
输入项目名字,选择JDK1.7以上版本,并选择JPA版本:
继续点下一步,知道出现下面这个界面,选择使用EclipseLink库,如果没有,请点游标的小图标下载,知道可以如图勾选,然后点finish:
这时,你应该能得到如下项目结构:
按自己的习惯,新建包。
接下来编写一个实体:
package com.anxpp.demo.jpa; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.Table; /** * 实体 * @author anxpp */ @Entity //注解表示实体 @Table //对应数据库的person表 public class Person { //自增长主键 @Id @GeneratedValue(strategy= GenerationType.AUTO) private int id; private String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "id:" + id + ",name:" + name; } }
这时应该会报错,因为persistence.xml文件中还没配置实体,而且其他配置信息也还没有,下面就为其添加位置,添加后完整的persistence.xml文件内容如下(为了演示输出时不会有太多内容,日志设为OFF):
<?xml version="1.0" encoding="UTF-8"?> <persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd"> <persistence-unit name="JPADemo"> <class>com.anxpp.demo.jpa.Person</class> <properties> <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/jpademo" /> <property name="javax.persistence.jdbc.user" value="root" /> <property name="javax.persistence.jdbc.password" value="root" /> <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" /> <property name="eclipselink.logging.level" value="OFF" /> <property name="eclipselink.ddl-generation" value="create-tables" /> </properties> </persistence-unit> </persistence>
很显然,上面配置的需要访问的数据库是MySQL,所以我们需要为项目添加jdbc驱动,本人使用的 mysql-connector-java-5.1.9.jar ,读者可以按自己想要的添加。
接下来就是CRUD测试方法的编写,下面将代码一并贴出(代码仅供介绍JPA,编码方式没有任何参考价值):
package com.anxpp.demo.jpa; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.Persistence; /** * 测试使用 * @author anxpp */ public class TestUse { public static void main(String args[]){ TestUse testUse = new TestUse(); testUse.save(); //添加一条 testUse.findAll(); //查看结果1 testUse.save(); //再添加一条 testUse.findAll(); //查看结果2 testUse.update(); //更新数据 testUse.findAll(); //查看结果3 testUse.del(); //删除数据 testUse.findAll(); //查看结果4 testUse.close(); System.out.println("-------------------------"); } EntityManagerFactory emfactory = Persistence.createEntityManagerFactory("JPADemo"); EntityManager entitymanager = emfactory.createEntityManager(); public void save() { entitymanager.getTransaction().begin(); Person person = new Person(); person.setName("anxpp"); entitymanager.persist(person); entitymanager.getTransaction().commit(); } public void update() { entitymanager.getTransaction().begin(); Person person=entitymanager.find(Person.class,1); person.setName(person.getName() + "+"); entitymanager.getTransaction().commit(); } public void findAll(){ entitymanager.getTransaction().begin(); @SuppressWarnings("unchecked") List<Person> persons=entitymanager.createQuery("select p from Person p").getResultList(); System.out.println("当前查询结果:" + persons); entitymanager.getTransaction().commit(); } public void del() { entitymanager.getTransaction().begin(); Person person=entitymanager.find( Person.class, 1 ); entitymanager.remove(person); entitymanager.getTransaction().commit(); } public void close(){ entitymanager.close(); emfactory.close(); } }
以下是输出结果:
当前查询结果:[id:1,name:anxpp] 当前查询结果:[id:1,name:anxpp, id:2,name:anxpp] 当前查询结果:[id:1,name:anxpp+, id:2,name:anxpp] 当前查询结果:[id:2,name:anxpp] -------------------------
但是JPA毕竟是一种重量级的,需要Jave EE 容器支持(如Jboss)。
JPA有一套标准的API,这里不多介绍,其实并没有很多人去详细了解这些。后面会介绍Spring Data JPA,也应是我们开发时框架的首选。相对传统的Spring+Hibernate,Spring Data JPA+Hibernate是一种更先进,也更方便简单的用法,相应的文章,也会在最近一两天编辑完成,完成后会在本文添加链接,欢迎大家阅读,互相学习探讨。
相关文章推荐
- Java for-each循环
- java中带继承类的加载顺序详解及实战
- spring基础知识汇总及常见面试题目总结
- Java上传下载excel、解析Excel、生成Excel的问题
- 基于Servlet+JSP+JavaBean开发模式的用户登录注册
- Java 版 (精华区)--Frame和Panel的区别【转载
- 两个java数组删除相同元素
- HDU 1042 N! (大数阶乘,紫书上的方法超时!!还是Java大法好!!)
- Windows 10 Java环境变量配置
- 浅析Java虚拟机结构与机制
- Java基础之static和final的用法
- eclipse运行go文件,报错“Resource donesnt have a corresponding Go paceage.”
- Java Web中内置对象--response重定向
- Java中的集合总结
- JAVA 就六次作业 抽奖
- Java第二次听课笔记(20160512)
- Java基础 数组
- Java进阶学习第十七天——JDBC入门学习
- Spring计划
- Eclipse exits automatically exit code 127