成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在Spring框架中集成JPA實例

開發(fā) 后端
本文向您介紹在Spring框架中集成JPA的實例,包括持久層DAO接口的編寫和Spring的配置等。

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

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

實體類MyUser,使用JPA注解實現(xiàn)到數(shù)據(jù)庫表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不是數(shù)據(jù)庫中的字段,使用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注解,聲明事務(wù)。

DAO實現(xiàn)類,如下所示:

    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來實現(xiàn)訪問數(shù)據(jù)庫,在Spring的配置文件中要注入一個org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean。#p#

Spring的配置文件applicationContext.xml的內(nèi)容如下所示:

   



















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




 

在META-INF目錄下,還要加一個persistence.xml配置文件,如下所示:
    

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

心得總結(jié)

感覺自己對JPA的理解還是不怎么深刻。

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

似乎使用JpaTemplate沒有使用HibernateTemplate方便,尤其是在執(zhí)行插入、修改、刪除記錄的時候。修改和刪除記錄需要先把數(shù)據(jù)庫中對應(yīng)的記錄加載出來,才能執(zhí)行修改和刪除操作。

查詢數(shù)據(jù)庫倒是很容易,因為根本不需要事務(wù),如果沒有事務(wù),插入、修改和刪除操作就不能實現(xiàn)。

在Spring中使用JPA,感覺代價比較大,使用起來不容易,出錯不容易調(diào)試。

比較好的地方就是。如果數(shù)據(jù)庫中的表很多,無需編寫大量的XML文件去映射,而且只需要從POJO中就可以非常直觀地看到各個表之間的關(guān)系。

您正在閱讀:在Spring框架中集成JPA實例

【編輯推薦】

  1. Spring中文手冊RC2隨Spring2.0同步全球發(fā)行
  2. Eclipse開發(fā): Struts 2 + Spring 2 + JPA + AJAX
  3. Spring 2.5 中配置 JPA
責(zé)任編輯:張攀 來源: 百度空間
相關(guān)推薦

2024-01-31 09:42:11

RabbitMQ消息隊列.NET

2009-06-23 09:33:20

FCKEditorJSFJSP

2011-07-20 17:10:05

iPhone iAd

2014-12-31 09:56:29

Ehcache

2009-01-03 15:01:16

ibmdwLptus

2009-01-03 14:43:55

ibmdwPHPsMash

2014-09-28 14:53:39

滲透BurpSuiteSqlmap

2011-06-29 09:42:12

Visual Stud Qt Opensource

2009-06-18 15:28:08

Glassfish JSpring

2016-04-20 09:47:40

MapBoxAndroid地圖

2009-06-11 13:28:18

Glassfish集成

2012-10-18 10:12:42

IBMdw

2011-03-04 09:40:42

AJAX開發(fā)集成數(shù)據(jù)庫

2024-01-03 07:19:19

LogbackLog4j2Java

2009-06-19 16:25:34

Flex與Spring

2009-06-01 14:32:10

jpa技術(shù)Java框架

2009-06-18 15:56:49

Struts和Spri

2009-03-24 10:30:35

SpringStruts集成

2011-03-02 17:42:35

2025-01-26 00:00:40

Seata分布式事務(wù)
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 午夜视频在线观看网站 | 免费久久99精品国产婷婷六月 | 欧美日韩中文国产一区发布 | 久久精品男人的天堂 | 久久久久久久久久久久久9999 | 欧美成人a∨高清免费观看 色999日韩 | 免费a v网站 | 久久99精品久久久久久 | 在线a视频网站 | 欧美日韩网站 | 久久久久国产 | 日韩欧美国产一区二区 | 欧美一区成人 | 伊人免费网 | 91精品国产91久久久久福利 | 国产毛片久久久 | 欧洲亚洲精品久久久久 | www久久 | 国产不卡一区 | 欧美在线亚洲 | 久久久久久国产精品mv | a在线观看 | 午夜小电影 | 天天色天天色 | 精品国产91亚洲一区二区三区www | 国产日韩精品一区 | 中文字幕成人在线 | 日韩在线视频一区 | 久久久精品久 | 蜜桃官网 | 99精品免费 | 国产精品一区久久久 | 国产精品美女久久久久久免费 | 中文字幕一区在线 | 国产高清视频一区 | 91一区二区三区 | 久久久精品 | 国产精品视频久久久 | 亚洲精品乱码 | 久久精品欧美一区二区三区不卡 | 一区二区免费看 |