博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Maven 版 JPA 最佳实践(转)
阅读量:6188 次
发布时间:2019-06-21

本文共 15028 字,大约阅读时间需要 50 分钟。

项目结构图

数据库环境

  • 数据库: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
<project xmlns=
""
xmlns:xsi=
""
xsi:schemaLocation=
" "
>
<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"
?>
<persistence xmlns=
""
xmlns:xsi=
""
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://www.cnblogs.com/ctoroad/p/4111447.html

 

你可能感兴趣的文章
jdk8中新的获取时间的方式
查看>>
常用命令所在的rpm包
查看>>
UltraEdit强大的搜索功能,有提示的正则匹配搜索匹配替换
查看>>
android ProgressDialog 不可点掉
查看>>
element-admin 点击侧边栏刷新当前路由
查看>>
rpm 的常规用法
查看>>
CodeIgniter通过hook的方式实现简单的权限控制
查看>>
Spring Boot中@ConfigurationProperties的使用
查看>>
MySQL与PostgreSQL的简单表关联更新
查看>>
Android 使用Javascript作为脚本计算器
查看>>
Android 贝塞尔曲线实践——旋转的七色花朵
查看>>
不得不知道的golang之sync.Mutex互斥锁源码分析
查看>>
【PHP】用正则表达式过滤js代码(注意这个分析过程)
查看>>
Redis集群搭建
查看>>
使用PowerMock模拟静态方法
查看>>
nginx静态资源分离部署
查看>>
省市区三级联动效果--城市数据来源百度js文件,无需后台交互
查看>>
Git之SSH与HTTPS免密码配置
查看>>
《11招玩转网络安全》之第四招:low级别的DVWA SQL注入
查看>>
设计android程序框架需要注意的问题总结
查看>>