在Spring框架中集成JPA实例
创始人
2024-03-30 06:01:10
0

Hibernate 3.2支持JPA注解,Spring集成JPA是可选的。

下面是Spring集成JPA的一个例子。

实体类MyUser,使用JPA注解实现到数据库表myUser的映射,如下所示:

   package org.shirdrn.entity;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Transient;
@Entity
public class MyUser {
private Long id;
private String userName;
private String password;
private String gender;
private Integer age;
private Integer birthYear;
private String addr;
private String email;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
public Long getId() {
   return id;
}
public void setId(Long id) {
   this.id = id;
}
@Column(name="userName")
public String getUserName() {
   return userName;
}
public void setUserName(String userName) {
   this.userName = userName;
}
@Column(name="password")
public String getPassword() {
   return password;
}
public void setPassword(String password) {
   this.password = password;
}
@Column(name="gender")
public String getGender() {
   return gender;
}
public void setGender(String gender) {
   this.gender = gender;
}
@Column(name="age")
public Integer getAge() {
   return age;
}
public void setAge(Integer age) {
   this.age = age;
}
@Column(name="addr")
public String getAddr() {
   return addr;
}
public void setAddr(String addr) {
   this.addr = addr;
}
@Column(name="email")
public String getEmail() {
   return email;
}
public void setEmail(String email) {
   this.email = email;
}
@Transient
public Integer getBirthYear() {
   return new Integer(2008-age);
}
public void setBirthYear(Integer age) {
   this.birthYear = new Integer(2008-age);
}
}


其中,birthYear不是数据库中的字段,使用JPA的@Transient注解,在映射的时候,会忽略掉该成员。

持久层DAO接口如下:

   package org.shirdrn.dao;
import java.util.List;
import org.shirdrn.entity.MyUser;
import org.springframework.transaction.annotation.Transactional;
@Transactional
public interface MyUserDAO {
public void createMyUser(MyUser myUser);
public void deleteMyUser(MyUser myUser);
public void updateMyUser(MyUser myUser);
public List queryMyUser(String queryString);
public List queryAll();
}


这里,使用了JPA注解,声明事务。

DAO实现类,如下所示:

    package org.shirdrn.dao.impl;
import java.util.List;
import org.shirdrn.dao.MyUserDAO;
import org.shirdrn.entity.MyUser;
import org.springframework.orm.jpa.support.JpaDaoSupport;
public class MyUserDAOImpl extends JpaDaoSupport implements MyUserDAO {
public void createMyUser(MyUser myUser) {
   getJpaTemplate().persist(myUser);
}
public void deleteMyUser(MyUser myUser) {
   MyUser dbMyUser = getJpaTemplate().find(MyUser.class, myUser.getId());
   getJpaTemplate().remove(dbMyUser);
}
public void updateMyUser(MyUser myUser) {
   MyUser dbMyUser = getJpaTemplate().find(MyUser.class, myUser.getId());
   if(myUser.getUserName() != null){
    dbMyUser.setUserName(myUser.getUserName());
   }
   if(myUser.getAddr() != null){
    dbMyUser.setAddr(myUser.getAddr());
   }
   getJpaTemplate().merge(dbMyUser);
}
@SuppressWarnings("unchecked")
public List queryMyUser(String queryString) {
   return (List)getJpaTemplate().find(queryString);
}
@SuppressWarnings("unchecked")
public List queryAll() {
   return (List)getJpaTemplate().find("from MyUser");
}
}


因为继承了JpaDaoSupport,索引需要获取一个JpaTemplate来实现访问数据库,在Spring的配置文件中要注入一个org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean。#p#

Spring的配置文件applicationContext.xml的内容如下所示:

   
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-2.0.xsd">




















abstract="false"lazy-init="default"autowire="default"
dependency-check="default">




 

在META-INF目录下,还要加一个persistence.xml配置文件,如下所示:
    
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"version="1.0">

org.hibernate.ejb.HibernatePersistence
org.shirdrn.entity.MyUser


接着,对增删改查操作进行测试,如下所示:

插入记录:

   packageorg.shirdrn.test;
importorg.shirdrn.dao.MyUserDAO;
importorg.shirdrn.entity.MyUser;
importorg.springframework.context.ApplicationContext;
importorg.springframework.context.support.ClassPathXmlApplicationContext;
publicclassTestCreateMyUser{
publicstaticvoidmain(String[]args){
MyUserDAOmyUserDAO=(MyUserDAO)ctx.getBean("myUserDAOImpl");
MyUsermyUser=newMyUser();
myUser.setUserName("JohnXa");
myUser.setPassword("123456");
myUser.setGender("男");
myUser.setAge(newInteger(25));
myUser.setAddr("NewYork");
myUser.setEmail("john@hotmail.com");
myUserDAO.createMyUser(myUser);
}
}

删除记录:
    packageorg.shirdrn.test;
importorg.shirdrn.dao.MyUserDAO;
importorg.shirdrn.entity.MyUser;
importorg.springframework.context.ApplicationContext;
importorg.springframework.ClassPathXmlApplicationContext;
publicclassTestDeleteMyUser{
publicstaticvoidmain(String[]args){
ApplicationContextctx=newClassPathXml("applicationContext.xml");
MyUserDAOmyUserDAO=(MyUserDAO)ctx.getBean("myUserDAOImpl");
MyUsermyUser=newMyUser();
myUser.setId(newLong(29));
myUserDAO.deleteMyUser(myUser);

修改记录:
    packageorg.shirdrn.test;
importorg.shirdrn.dao.MyUserDAO;
importorg.shirdrn.entity.MyUser;
importorg.springframework.context.ApplicationContext;
importorg.springframework.context.ClassPathXmlApplicationContext;

 

publicclassTestUpdateMyUser{
publicstaticvoidmain(String[]args){
ApplicationContextctx=newClassPathXmlApplicationContext("applicationContext.xml");
MyUserDAOmyUserDAO=(MyUserDAO)ctx.getBean("myUserDAOImpl");
MyUsermyUser=newMyUser();
myUser.setId(newLong(28));
myUser.setAddr("北京市");
myUserDAO.updateMyUser(myUser);
}
}


查询记录:
   packageorg.shirdrn.test;
importjava.util.List;
importorg.shirdrn.dao.MyUserDAO;
importorg.shirdrn.entity.MyUser;
importorg.springframework.context.ApplicationContext;
importorg.springframework.context.ClassPathXmlApplicationContext;
publicclassTestQueryAllMyUser{
publicstaticvoidmain(String[]args){
ApplicationContextctx=newClassPathXmContext("applicationContext.xml");
MyUserDAOmyUserDAO=(MyUserDAO)ctx.getBean("myUserDAOImpl");
Listlist=myUserDAO.queryMyUser("fromMyUser");
for(MyUseruser:list){
System.out.println("ID:"+user.getId()+
"|姓名:"+user.getUserName()+
"|密码:"+user.getPassword()+
"|性别:"+user.getGender()+
"|年龄:"+user.getAge()+
"|住址:"+user.getAddr()+
"|邮箱:"+user.getEmail());
}
}
}

心得总结

感觉自己对JPA的理解还是不怎么深刻。

JpaTemplate提供的一些操作的方法,感觉不是很快就能理解的。

似乎使用JpaTemplate没有使用HibernateTemplate方便,尤其是在执行插入、修改、删除记录的时候。修改和删除记录需要先把数据库中对应的记录加载出来,才能执行修改和删除操作。

查询数据库倒是很容易,因为根本不需要事务,如果没有事务,插入、修改和删除操作就不能实现。

在Spring中使用JPA,感觉代价比较大,使用起来不容易,出错不容易调试。

比较好的地方就是。如果数据库中的表很多,无需编写大量的XML文件去映射,而且只需要从POJO中就可以非常直观地看到各个表之间的关系。

您正在阅读:在Spring框架中集成JPA实例

【编辑推荐】

  1. Spring中文手册RC2随Spring2.0同步全球发行
  2. Eclipse开发: Struts 2 + Spring 2 + JPA + AJAX
  3. Spring 2.5 中配置 JPA

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...