项目结构图

数据库环境

  • 数据库: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 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

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
<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

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
<?xml version="1.0" encoding="UTF-8"?>
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

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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
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

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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
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

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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
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();
}
}

运行结果

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
[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

完整工程源代码

下载地址:http://download.csdn.net/detail/xuxiheng/8181849

参考文档

  1. 在Java SE环境下使用JPA1.0(1)

  2. Toplink JPA简介

http://www.cnblogs.com/ctoroad/p/4111447.html

Maven 版 JPA 最佳实践(转)的更多相关文章

  1. Maven 版 JPA 最佳实践

    项目结构图 数据库环境 数据库:MySQL 版本:5.x 数据库名:jpa-demo 用户名密码:root/1234 代码清单 1:数据库脚本: /* Navicat MySQL Data Trans ...

  2. (七)Maven使用的最佳实践

    这里说一下在使用Maven过程中不是必须的,但十分有用的几个实践,关键时刻或许能解决您的问题. 1.设置MAVEN_OPTS环境变量 通常需要设置MAVEN_OPTS的值为-Xms128m -Xmx5 ...

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

    原文地址:https://blog.csdn.net/liupeifeng3514/article/details/79544201 1.设置MAVEN_OPTS环境变量 通常需要设置MAVEN_OP ...

  4. Maven最佳实践:版本管理

    什么是版本管理 首先,这里说的版本管理(version management)不是指版本控制(version control),但是本文假设你拥有基本的版本控制的知识,了解subversion的基本用 ...

  5. Maven最佳实践:管理依赖

    From:http://juvenshun.iteye.com/blog/337405 Maven最佳实践:管理依赖 "If I have seen further it is by sta ...

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

    数据库性能最佳实践 当应用须要连接数据库时.那么应用的性能就可能收到数据库性能的影响. 比方当数据库的I/O能力存在限制,或者因缺失了索引而导致运行的SQL语句须要对整张表进行遍历.对于这些问题.只相 ...

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

    什么是版本管理 首先,这里说的版本管理(version management)不是指版本控制(version control),但是本文假设你拥有基本的版本控制的知识,了解subversion的基本用 ...

  8. maven 安装与配置最佳实践

    配置Maven环境变量 1.新建 maven home 环境变量      变量名:M2_HOME     变量值:D:\ProgramFiles\apache-maven-3.5.4       2 ...

  9. 版本控制之最佳实践(Git版)

    现如今,应该每个开发者都在使用版本控制工具了吧.然而,如果你理解版本控制的基本规则,你便能更好地发挥它的效用.在此,我们汇总了一些最佳实践,希望你在使用Git做版本控制时能够了然于心.得心应手. 1. ...

随机推荐

  1. 转 C#中静态方法与非静态方法区别比较

    C#静态方法与非静态方法的区别不仅仅是概念上的,那么他们有什么具体的区别呢?让我们通过本文向你做一下解析. C#的类中可以包含两种方法:C#静态方法与非静态方法.那么他们的定义有什么不同呢?他们在使用 ...

  2. 给定数组A,大小为n,现给定数X,判断A中是否存在两数之和等于X

    题目:给定数组A,大小为n,现给定数X,判断A中是否存在两数之和等于X 思路一: 1,先采用归并排序对这个数组排序, 2,然后寻找相邻<k,i>的两数之和sum,找到恰好sum>x的 ...

  3. HDFS之HBase伪分布安装

    1.HBase简介 HBase是Apache Hadoop中的一个子项目,Hbase依托于Hadoop的HDFS作为最基本存储基础单元,通过使用hadoop的DFS工具就可以看到这些这些数据 存储文件 ...

  4. WinSock网络编程基础(3)server

    上一篇讲的是简单的发送数据的客户端的实现.接下来讲的是如何实现收发数据服务器.这里说的服务器其实就是一个进程,它需要等待任意数量的客户端与之建立起连接,以便响应它们的请求. 服务器必须在已知的名称上监 ...

  5. linux中的ps命令用法。

    在linux中使用ps命令可以查看有哪些进程在运行和运行的状态.进程是否结束.进程有没有僵尸.哪些进程占用了过多的资源等等. ps命令最常用的是用于监控后台进程的工作情况. 名称:ps 使用权限:所有 ...

  6. 《Pointers On C》读书笔记(第一章 快速上手)

    1.C语言是一种自由格式的程序设计语言,没有规则要求我们必须如何书写语句.然而,如果我们在编写程序时能够遵守一些约定还是非常值得的,它可以使代码更加容易阅读和修改.另外,预处理命令有较为严格的规则. ...

  7. Groovy中那些神奇注解之InheritConstructors

    上一篇:Groovy中那些神奇注解之ToString 写完ToString,本来想今天就写到这了,突然觉得InheritConstructors注解实在也是个神器,写起来也没多少字,还是写了吧. In ...

  8. Swagger+Spring MVC框架学习分享

    [html] view plain copy 最近参与公司接口编写,Android和IOS端都要调用这些接口,需要对接调试,如果没有一个接口文档,管理接口,别人用了接口,也不知道接口怎么用,接口上有什 ...

  9. redis的分布式解决方式--codis

    codis是豌豆荚开源的分布式server.眼下处于稳定阶段. 原文地址:https://github.com/wandoulabs/codis/blob/master/doc/tutorial_zh ...

  10. 1.语言概述-JavaScript权威指南笔记

    上周三的时候交给老板目前的项目第一个迭代回顾会的总结.原本是以综述性的表述方式写的,交给他之后表示程序员不要长篇大论.总结要分为优点缺点期望等等块,每块列出条目,简明扼要的表达出来.这里也用这种风格. ...