Maven 版 JPA 最佳实践

项目结构图

数据库环境

  • 数据库:MySQL
  • 版本:5.x
  • 数据库名:jpa-demo
  • 用户名密码:root/1234

代码清单 1:数据库脚本:

/*
Navicat MySQL Data Transfer

Source Server         : localhost
Source Server Version : 50525
Source Host           : localhost:3306
Source Database       : jpa-demo

Target Server Type    : MYSQL
Target Server Version : 50525
File Encoding         : 65001

Date: 2014-11-20 20:09:27
*/

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for `address`
-- ----------------------------
DROP TABLE IF EXISTS `address`;
CREATE TABLE `address` (
  `addressID` int(11) NOT NULL,
  `city` varchar(55) NOT NULL,
  `street` varchar(55) NOT NULL,
  `zip` varchar(8) NOT NULL,
  PRIMARY KEY (`addressID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of address
-- ----------------------------
INSERT INTO `address` VALUES (‘1‘, ‘深圳‘, ‘坂田市场‘, ‘518001‘);
INSERT INTO `address` VALUES (‘2‘, ‘深圳‘, ‘坂田路口‘, ‘518002‘);
INSERT INTO `address` VALUES (‘3‘, ‘深圳‘, ‘四季花城‘, ‘518003‘);

-- ----------------------------
-- Table structure for `userinfo`
-- ----------------------------
DROP TABLE IF EXISTS `userinfo`;
CREATE TABLE `userinfo` (
  `userID` int(11) NOT NULL,
  `username` varchar(20) NOT NULL,
  `birthday` datetime DEFAULT NULL,
  `sex` varchar(8) NOT NULL,
  `addressID` int(11) NOT NULL,
  PRIMARY KEY (`userID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of userinfo
-- ----------------------------
INSERT INTO `userinfo` VALUES (‘1‘, ‘张金雄‘, null, ‘male‘, ‘1‘);
INSERT INTO `userinfo` VALUES (‘2‘, ‘李某某‘, null, ‘male‘, ‘2‘);
INSERT INTO `userinfo` VALUES (‘3‘, ‘王某某‘, ‘2006-08-10 00:00:00‘, ‘female‘, ‘3‘);
INSERT INTO `userinfo` VALUES (‘4‘, ‘陈某某‘, ‘2006-08-12 00:00:00‘, ‘male‘, ‘3‘);

源代码

代码清单 2:pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<groupId>com.coderdream</groupId>
	<artifactId>jpa-demo</artifactId>
	<packaging>war</packaging>
	<version>0.0.1-SNAPSHOT</version>
	<name>jpa-demo Maven Webapp</name>
	<url>http://maven.apache.org</url>
	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<junit.version>4.11</junit.version>
		<mysql.version>5.1.17</mysql.version>
		<slf.version>1.7.5</slf.version>
		<toplink.essentials.version>2.1-60f</toplink.essentials.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
			<version>${junit.version}</version>
			<scope>test</scope>
		</dependency>

		<dependency>
			<groupId>toplink.essentials</groupId>
			<artifactId>toplink-essentials</artifactId>
			<version>${toplink.essentials.version}</version>
		</dependency>

		<dependency>
			<groupId>toplink.essentials</groupId>
			<artifactId>toplink-essentials-agent</artifactId>
			<version>${toplink.essentials.version}</version>
		</dependency>

		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-log4j12</artifactId>
			<version>${slf.version}</version>
		</dependency>

		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>${mysql.version}</version>
		</dependency>
	</dependencies>
	<build>
		<finalName>jpa-demo</finalName>
	</build>
</project>

代码清单 3:persistence.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
	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">

	<persistence-unit name="piscesPU" transaction-type="RESOURCE_LOCAL">
		<provider>
			oracle.toplink.essentials.PersistenceProvider
		</provider>
		<class>com.coderdream.model.UserInfo</class>
		<class>com.coderdream.model.Address</class>
		<properties>
			<!-- 数据库连接配置, JDBC驱动 -->
			<property name="toplink.jdbc.driver" value="com.mysql.jdbc.Driver" />
			<!-- 数据库连接配置,URL -->
			<property name="toplink.jdbc.url" value="jdbc:mysql://localhost:3306/jpa-demo" />
			<!-- 数据库连接配置, 用户名 -->
			<property name="toplink.jdbc.user" value="root" />
			<!-- 数据库连接配置, 密码 -->
			<property name="toplink.jdbc.password" value="1234" />
		</properties>
	</persistence-unit>

</persistence>

代码清单 4:Address.java

package com.coderdream.model;

import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;

@Entity
public class Address implements Serializable {
	// 地址id, 不能为空, 必须唯一
	@Id
	@Column(name = "addressid", unique = true, nullable = false)
	private int addressid;

	// 城市, 不能为空
	@Column(name = "city", nullable = false)
	private String city;

	// 街道, 不能为空
	@Column(name = "street", nullable = false)
	private String street;

	// 邮政编码, 不能为空
	@Column(name = "zip", nullable = false)
	private String zip;

	public Address() {
	}

	public Address(int addressid) {
		this.setAddressid(addressid);
	}

	public int getAddressid() {
		return this.addressid;
	}

	public void setAddressid(int addressid) {
		this.addressid = addressid;
	}

	public String getCity() {
		return this.city;
	}

	public void setCity(String city) {
		this.city = city;
	}

	public String getStreet() {
		return street;
	}

	public void setStreet(String street) {
		this.street = street;
	}

	public String getZip() {
		return this.zip;
	}

	public void setZip(String zip) {
		this.zip = zip;
	}

	@Override
	public int hashCode() {
		return this.addressid;
	}

	@Override
	public boolean equals(Object object) {
		if (!(object instanceof Address))
			return false;
		final Address other = (Address) object;
		return this.addressid == other.addressid;
	}

	@Override
	public String toString() {
		return "Address[addressid=" + getAddressid() + ", city=‘" + getCity() + "‘, street=‘" + getStreet() + "‘, zip=‘" + getZip() + "";
	}
}

代码清单 5:UserInfo.java

package com.coderdream.model;

import java.io.Serializable;
import java.sql.Timestamp;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToOne;
import static javax.persistence.CascadeType.*;

@Entity
public class UserInfo implements Serializable {
	// 用户id, 不能为空, 必须唯一
	@Id
	@Column(name = "userid", unique = true, nullable = false)
	private int userid;

	// 用户名, 不能为空
	@Column(name = "userName", nullable = false)
	private String userName;

	// 性别, 不能为空
	@Column(name = "sex", nullable = false)
	private String sex;

	// 出生日期, 可以为空
	@Column(name = "birthday")
	private Timestamp birthday;

	// 地址, 不能为空
	// PERSIST 表示更新、新增UserInfo数据时会同时更新、新增Address的数据
	// REMOVE 表示从数据库删除UserInfo会同时删除Address表中对应的数据
	@OneToOne(cascade = { PERSIST, REMOVE })
	@JoinColumn(name = "addressID", nullable = false)
	private Address address;

	public UserInfo() {
	}

	public UserInfo(int userid) {
		this.setUserid(userid);
	}

	@Override
	public int hashCode() {
		return this.getUserid();
	}

	@Override
	public boolean equals(Object object) {
		if (!(object instanceof UserInfo))
			return false;
		final UserInfo other = (UserInfo) object;
		return this.userid == other.userid;
	}

	@Override
	public String toString() {
		return "UserInfo[userid=" + this.userid + ", userName=‘" + userName + "‘, sex=‘" + sex + "‘, birthday=" + birthday + ", address="
				+ address + "";
	}

	public int getUserid() {
		return userid;
	}

	public void setUserid(int userid) {
		this.userid = userid;
	}

	public String getUserName() {
		return userName;
	}

	public void setUserName(String userName) {
		this.userName = userName;
	}

	public Timestamp getBirthday() {
		return birthday;
	}

	public void setBirthday(Timestamp birthday) {
		this.birthday = birthday;
	}

	public String getSex() {
		return sex;
	}

	public void setSex(String sex) {
		this.sex = sex;
	}

	public Address getAddress() {
		return address;
	}

	public void setAddress(Address address) {
		this.address = address;
	}
}

代码清单 6:SimpleService.java

package com.coderdream.service;

import java.util.List;

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

import com.coderdream.model.Address;
import com.coderdream.model.UserInfo;

public class SimpleService {

	/**
	 * 删除用户id=6的数据
	 */
	public static void delete() {
		final EntityManagerFactory emf = Persistence.createEntityManagerFactory("piscesPU");
		final EntityManager em = emf.createEntityManager();
		// 找不到数据的话这里会抛异常
		UserInfo info = em.find(UserInfo.class, 6);
		try {
			em.getTransaction().begin();
			em.remove(info);
			em.getTransaction().commit();
		} finally {
			em.close();
		}
	}

	/**
	 * 修改用户id=6的数据
	 */
	public static void update() {
		final EntityManagerFactory emf = Persistence.createEntityManagerFactory("piscesPU");
		final EntityManager em = emf.createEntityManager();
		// 找不到数据的话这里会抛异常
		UserInfo info = em.find(UserInfo.class, 6);
		info.setUserName("哈哈");
		info.getAddress().setStreet("坂田2");
		try {
			em.getTransaction().begin();
			// 自动将info更新到数据库
			em.getTransaction().commit();
		} finally {
			em.close();
		}
	}

	/**
	 * 查询所有用户数据
	 */
	public static void query() {
		final EntityManagerFactory emf = Persistence.createEntityManagerFactory("piscesPU");
		long s = System.currentTimeMillis();
		// 数据库连接失败这里会抛出异常
		final EntityManager em = emf.createEntityManager();
		long e = System.currentTimeMillis();
		System.out.println("连接数据库耗时: " + (e - s) + "毫秒");
		// 获取数据
		@SuppressWarnings("unchecked")
		List<UserInfo> list = em.createQuery("SELECT a FROM UserInfo a").getResultList();
		int i = 0;
		for (UserInfo info : list) {
			System.out.println("第" + (++i) + "个值为: " + info);
		}
		em.close();
	}

	/**
	 * 创建用户id=6的一条数据, 地址id=6
	 */
	public static void create() {
		final EntityManagerFactory emf = Persistence.createEntityManagerFactory("piscesPU");
		final EntityManager em = emf.createEntityManager();

		UserInfo info = new UserInfo(6);
		info.setSex("male");
		info.setUserName("张某某");
		info.setBirthday(new java.sql.Timestamp(System.currentTimeMillis()));
		Address naddr = new Address(6);
		naddr.setCity("深圳");
		naddr.setStreet("坂田");
		naddr.setZip("518000");
		info.setAddress(naddr);

		try {
			em.getTransaction().begin();
			em.persist(info);
			em.getTransaction().commit();
		} finally {
			em.close();
		}
	}

	/**
	 * 主函数
	 */
	public static void main(String[] args) throws Throwable {
		SimpleService.query();
		SimpleService.create();
		System.out.println("新增一条数据后进行查询");
		SimpleService.query();
		SimpleService.update();
		System.out.println("修改一条数据后进行查询");
		SimpleService.query();
		SimpleService.delete();
		System.out.println("删除一条数据后进行查询");
		SimpleService.query();
	}
}

运行结果

[TopLink Info]: 2014.11.20 08:24:08.134--ServerSession(1112823384)--TopLink, version: Oracle TopLink Essentials - 2.1 (Build 60f (01/07/2009))
[TopLink Info]: 2014.11.20 08:24:08.822--ServerSession(1112823384)--file:/E:/E_441_64/workspace/jpa-demo/target/classes/-piscesPU login successful
连接数据库耗时: 1264毫秒
第1个值为: UserInfo[userid=1, userName=‘张金雄‘, sex=‘male‘, birthday=null, address=Address[addressid=1, city=‘深圳‘, street=‘坂田市场‘, zip=‘518001
第2个值为: UserInfo[userid=2, userName=‘李某某‘, sex=‘male‘, birthday=null, address=Address[addressid=2, city=‘深圳‘, street=‘坂田路口‘, zip=‘518002
第3个值为: UserInfo[userid=3, userName=‘王某某‘, sex=‘female‘, birthday=2006-08-10 00:00:00.0, address=Address[addressid=3, city=‘深圳‘, street=‘四季花城‘, zip=‘518003
第4个值为: UserInfo[userid=4, userName=‘陈某某‘, sex=‘male‘, birthday=2006-08-12 00:00:00.0, address=Address[addressid=3, city=‘深圳‘, street=‘四季花城‘, zip=‘518003
新增一条数据后进行查询
连接数据库耗时: 0毫秒
第1个值为: UserInfo[userid=1, userName=‘张金雄‘, sex=‘male‘, birthday=null, address=Address[addressid=1, city=‘深圳‘, street=‘坂田市场‘, zip=‘518001
第2个值为: UserInfo[userid=2, userName=‘李某某‘, sex=‘male‘, birthday=null, address=Address[addressid=2, city=‘深圳‘, street=‘坂田路口‘, zip=‘518002
第3个值为: UserInfo[userid=3, userName=‘王某某‘, sex=‘female‘, birthday=2006-08-10 00:00:00.0, address=Address[addressid=3, city=‘深圳‘, street=‘四季花城‘, zip=‘518003
第4个值为: UserInfo[userid=4, userName=‘陈某某‘, sex=‘male‘, birthday=2006-08-12 00:00:00.0, address=Address[addressid=3, city=‘深圳‘, street=‘四季花城‘, zip=‘518003
第5个值为: UserInfo[userid=6, userName=‘张某某‘, sex=‘male‘, birthday=2014-11-20 20:24:09.102, address=Address[addressid=6, city=‘深圳‘, street=‘坂田‘, zip=‘518000
修改一条数据后进行查询
连接数据库耗时: 0毫秒
第1个值为: UserInfo[userid=1, userName=‘张金雄‘, sex=‘male‘, birthday=null, address=Address[addressid=1, city=‘深圳‘, street=‘坂田市场‘, zip=‘518001
第2个值为: UserInfo[userid=2, userName=‘李某某‘, sex=‘male‘, birthday=null, address=Address[addressid=2, city=‘深圳‘, street=‘坂田路口‘, zip=‘518002
第3个值为: UserInfo[userid=3, userName=‘王某某‘, sex=‘female‘, birthday=2006-08-10 00:00:00.0, address=Address[addressid=3, city=‘深圳‘, street=‘四季花城‘, zip=‘518003
第4个值为: UserInfo[userid=4, userName=‘陈某某‘, sex=‘male‘, birthday=2006-08-12 00:00:00.0, address=Address[addressid=3, city=‘深圳‘, street=‘四季花城‘, zip=‘518003
第5个值为: UserInfo[userid=6, userName=‘哈哈‘, sex=‘male‘, birthday=2014-11-20 20:24:09.102, address=Address[addressid=6, city=‘深圳‘, street=‘坂田2‘, zip=‘518000
删除一条数据后进行查询
连接数据库耗时: 0毫秒
第1个值为: UserInfo[userid=1, userName=‘张金雄‘, sex=‘male‘, birthday=null, address=Address[addressid=1, city=‘深圳‘, street=‘坂田市场‘, zip=‘518001
第2个值为: UserInfo[userid=2, userName=‘李某某‘, sex=‘male‘, birthday=null, address=Address[addressid=2, city=‘深圳‘, street=‘坂田路口‘, zip=‘518002
第3个值为: UserInfo[userid=3, userName=‘王某某‘, sex=‘female‘, birthday=2006-08-10 00:00:00.0, address=Address[addressid=3, city=‘深圳‘, street=‘四季花城‘, zip=‘518003
第4个值为: UserInfo[userid=4, userName=‘陈某某‘, sex=‘male‘, birthday=2006-08-12 00:00:00.0, address=Address[addressid=3, city=‘深圳‘, street=‘四季花城‘, zip=‘518003

完整工程源代码

下载地址:

参考文档

  1. 在Java SE环境下使用JPA1.0(1)
  2. Toplink JPA简介
时间: 2024-11-10 14:32:02

Maven 版 JPA 最佳实践的相关文章

Maven 版 JPA 最佳实践(转)

项目结构图 数据库环境 数据库:MySQL 版本:5.x 数据库名:jpa-demo 用户名密码:root/1234 代码清单 1:数据库脚本: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 /* Navicat MySQL

Maven 教程(7)— Maven使用的最佳实践

原文地址:https://blog.csdn.net/liupeifeng3514/article/details/79544201 1.设置MAVEN_OPTS环境变量 通常需要设置MAVEN_OPTS的值为-Xms128m -Xmx512m,因为Java默认的最大可用内存往往不能够满足Maven运行的需要,比如在项目较大时,使用Maven生成项目站点需要占用大量的内存,如果没有该配置,则很容易得到java.lang.OutOfMemeoryError异常.因此,一开始就配置该环境变量是推荐的

Maven最佳实践:版本管理

什么是版本管理 首先,这里说的版本管理(version management)不是指版本控制(version control),但是本文假设你拥有基本的版本控制的知识,了解subversion的基本用法.版本管理中说得版本是指构件(artifact)的版 本,而非源码的版本(如subversion中常见的rXXX,或者git中一次提交都有个sha1的commit号). 比如我有一个项目,其artifactId为myapp,随着项目的进展,我们会生成这样一些jar:myapp-1.0- SNAPS

Android和PHP开发最佳实践 (第2版)——互动出版网

这篇是计算机类的优质预售推荐>>>><Android和PHP开发最佳实践 (第2版)> 51CTO社区.PHPChina社区强烈推荐!国内第一本同时讲述Android客户端开发和PHP服务端开发的经典著作!市面上第一本把Android应用客户端加服务器开发的完整解决方案分析透彻的书 本书是国内第一本同时讲述Android客户端和PHP服务端开发的经典著作. 本书以一个完整的微博应用项目实例为主线,由浅入深地讲解了Android客户端开发和PHP服务端开发的思路和技巧.从

[Java Performance] 数据库性能最佳实践 - JPA和读写优化

数据库性能最佳实践 当应用需要连接数据库时,那么应用的性能就可能收到数据库性能的影响.比如当数据库的I/O能力存在限制,或者因缺失了索引而导致执行的SQL语句需要对整张表进行遍历.对于这些问题,仅仅对应用代码进行优化可能是不够,还需要了解数据库的知识和特点. 示例数据库 该数据库表示了128只股票在1年内(261个工作日)的股价信息. 其中有两张表:STOCKPRICE和STOCKOPTIONPRICE. STOCKPRICE中使用股票代码作为主键,另外还有日期字段.它有33408条记录(128

Maven最佳实践:版本管理【转】

什么是版本管理 首先,这里说的版本管理(version management)不是指版本控制(version control),但是本文假设你拥有基本的版本控制的知识,了解subversion的基本用法.版本管理中说得版本是指构件(artifact)的版本,而非源码的版本(如subversion中常见的rXXX,或者git中一次提交都有个sha1的commit号). 比如我有一个项目,其artifactId为myapp,随着项目的进展,我们会生成这样一些jar:myapp-1.0-SNAPSHO

微信公众平台开发最佳实践(第2版)

<微信公众平台开发最佳实践 第2版>微信公众平台开发经典之作全新改版,精心挑选最经典的商业项目开发,成千上万人次微信公众平台开发者从中受益 前言 出版说明 自从方倍工作室在博客园推出微信公众平台开发系列教程后,受到广大微信开发人员及爱好者的热情关注,相关文章的日访问量高达2万人次,而<微信公众平台开发入门教程>的阅读量超过50万,博客访问量总计超过500万,成为微信公众平台开发更新最快,传播最广.受众最多.资料最全的博客,很多博文被许多有影响力的网站转载,并被各大搜索引擎收录且排名

高性能网站建设进阶指南:Web开发者性能优化最佳实践 pdf扫描版

高性能网站建设进阶指南:Web开发者性能优化最佳实践是<高性能网站建设指南>姊妹篇.作者Steve Souders是Google Web性能布道者和Yahoo!前首席性能工程师.在本书中,Souders与8位专家分享了提升网站性能的最佳实践和实用建议,主要包括:理解Ajax性能,编写高效的JavaScript,创建快速响应的应用程序.无阻塞加载脚本, 跨域共享资源,无损压缩图片大小,使用块编码加快网页渲染:避免或取代iframe的方法,简化CSS选择符,以及其他技术.性能是任何一个网站成功的关

深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)PDF下载

网盘下载地址:深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)PDF下载 – 易分享电子书PDF资源网 作者: 周志明 出版社: 机械工业出版社 副标题: JVM高级特性与最佳实践 出版年: 2013-9-1 页数: 433 定价: 79.00元 装帧: 平装 内容简介 · · · · · · <深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)>内容简介:第1版两年内印刷近10次,4家网上书店的评论近4?000条,98%以上的评论全部为5星级的好评,是整个Java图书领域公