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

2) 创建配置文件persistence.xml 在项目src文件夹下创建一个META-INF文件夹(有就不用创建了), META-INF文件夹下建一个persistence.xml文件, 内容为:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" 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">
<!-- transaction-type 可选值有: JTA、RESOURCE_LOCAL ;
在Java EE 环境下默认值为JTA, 在Java SE 环境下默认值为RESOURCE_LOCAL;
如果值为JTA的话, 则必须要指定<jta-data-source>的值 -->
<persistence-unit name="piscesPU" transaction-type="RESOURCE_LOCAL">
<description>这是piscesPU持久化单元的一个简单描述</description>
<!-- 指明javax.persistence.spi.PersistenceProvider 的实现类, 一般来说该节点可以省略 -->
<provider>oracle.toplink.essentials.ejb.cmp3.EntityManagerFactoryProvider</provider>
<!-- 在Java SE环境下必须定义所有的实体Entity类, 也可以用 <mapping-file> 或<jar-file> 节点代替 -->
<class>org.pisces.persist.UserInfo</class>
<class>org.pisces.persist.Address</class>
<!--
//可以定义jndi资源代替properties节点中的数据库配置,
//但是在调用Persistence.createEntityManagerFactory方法前必须保证此资源已经注入程序中.
<jta-data-source>jdbc/persist</jta-data-source>
-->

<!-- properties节点是用来定义各种JPA实现包所定义的属性配置 -->
<!-- 下面列举的是toplink实现包中可以配置的部分属性 -->
<properties>
<!-- 数据库连接配置, JDBC驱动 -->
<property name="toplink.jdbc.driver" value="com.mysql.jdbc.Driver"/>
<!-- 数据库连接配置,URL -->
<property name="toplink.jdbc.url" value="jdbc:mysql://localhost:3306/piscesdb"/>
<!-- 数据库连接配置, 用户名 -->
<property name="toplink.jdbc.user" value="root"/>
<!-- 数据库连接配置, 密码 -->
<property name="toplink.jdbc.password" value=""/>

<!-- 数据库连接池配置, 可写的连接池的最大连接数, 默认为 10 -->
<property name="toplink.jdbc.write-connections.max" value="10"/>
<!-- 数据库连接池配置, 可写的连接池的最大连接数, 默认为 5 -->
<property name="toplink.jdbc.write-connections.min" value="5"/>
<!-- 数据库连接池配置, 只读的连接池的最大连接数, 默认为 2 -->
<property name="toplink.jdbc.read-connections.max" value="2"/>
<!-- 数据库连接池配置, 只读的连接池的最大连接数, 默认为 2 -->
<property name="toplink.jdbc.read-connections.min" value="2"/>
<!-- 数据库连接池配置, 只读的连接池是否可以共享, 默认为 false -->
<property name="toplink.jdbc.read-connections.shared" value="false"/>
<!-- 是否绑定所有jdbc属性, 默认为 true -->
<property name="toplink.jdbc.bind-parameters" value="true"/>

<!-- 缓冲配置, 以下三个属性值为默认设置;
可以 default改为entity名(@Entity注释中的name属性值)或者类名来指定该entity的缓冲配置, 如:
<property name="toplink.cache.size.org.pisces.persist.UserInfo" value="2"/>
<property name="toplink.cache.type.org.pisces.persist.UserInfo" value="SoftWeak"/>
<property name="toplink.cache.shared.org.pisces.persist.UserInfo" value="true"/>
-->
<property name="toplink.cache.size.org.pisces.persist.UserInfo" value="2"/>
<!-- 缓冲配置, 缓冲大小, 默认为 1000 -->
<property name="toplink.cache.size.default" value="1000"/>
<!-- 缓冲配置, 缓冲类型, 可选值为{ Weak、SoftWeak、HardWeak、Full、NONE }, 不区分大小, 默认为 SoftWeak -->
<property name="toplink.cache.type.default" value="SoftWeak"/>
<!-- 缓冲配置, 是否共享缓冲, 默认为 false -->
<property name="toplink.cache.shared.default" value="false"/>

<!-- 日志配置, 日志级别, 默认值为java.util.logging.Level在系统中的值 -->
<property name="toplink.logging.level" value="SEVERE"/>
<!-- 日志配置, 日志是否记录当前时间, 默认为 true -->
<property name="toplink.logging.timestamp" value="true"/>
<!-- 日志配置, 日志是否记录当前线程名, 默认为 true -->
<property name="toplink.logging.thread" value="true"/>
<!-- 日志配置, 日志是否记录当前会话名, 默认为 true -->
<property name="toplink.logging.session" value="true"/>
<!-- 日志配置, 日志是否记录异常堆栈, 默认为 true -->
<property name="toplink.logging.exceptions" value="true"/>

<!-- 目标数据库类型, 截至目前为止可选值为{ Auto、Oracle、Attunity、Cloudscape、Database、DB2、DB2Mainframe
、 DBase、Derby、HSQL、Informix、JavaDB、MySQL4、PostgreSQL、SQLAnyWhere、 SQLServer、Sybase、TimesTen },
不区分大小, 默认为 Auto, 即 TopLink自动匹配对应的数据库类型 -->
<property name="toplink.target-database" value="Auto"/>

<!-- 指定会话名称, 默认为系统自动产生唯一性名称-->
<property name="toplink.session-name" value="pisces_session_name"/>

<!-- 设置是否为weaving, 默认为 true -->
<property name="toplink.weaving" value="true"/>

<!-- 指定目标应用服务器类型, 截至目前为止可选值为{ None、OC4J_10_1_3、SunAS9 }(以后可能会扩展其他值的),
在 Java SE环境下值为 None, 不区分大小, 默认为 None -->
<property name="toplink.target-server" value="None"/>

<!-- 指定实现 oracle.toplink.essentials.tools.sessionconfiguration.DescriptorCustomizer 的类名,
toplink.descriptor.customizer. 为前缀, 后面跟entity名(@Entity注释中的name属性值)或者entity类名,
该类中的customize方法在执行 了所有的属性(除了 toplink.session.customizer 之外)后运行, 如:
<property name="toplink.descriptor.customizer.org.pisces.persist.UserInfo" value="org.pisces.persist.SimpleDescriptorCustomizer"/>
<property name="toplink.descriptor.customizer.org.pisces.persist.Address" value="org.pisces.persist.SimpleDescriptorCustomizer"/>
-->
<!-- 指定实现 oracle.toplink.essentials.tools.sessionconfiguration.SessionCustomizer 的类名,
该类中的customize方法在执行了所有的属性后运行, 如:
<property name="toplink.session.customizer" value="org.pisces.persist.SimpleSessionCustomizer"/>
-->
</properties>
</persistence-unit>
</persistence>
3) 创建Entity的管理类 管理类SimpleManager是用来对实体Entity进行操作管理的.
/*
* SimpleManager.java
*/

package org.pisces.persist;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;

/**
*
* @author kamhung
*/
publicclass SimpleManager {

private SimpleManager(){
//do nothing
}

/**
* 删除用户id=6的数据
*/
publicstaticvoid 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的数据
*/
publicstaticvoid 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();
}
}

/**
* 查询所有用户数据
*/
publicstaticvoid 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
*/
publicstaticvoid 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();
}
}
}

三、运行 1、 编写main函数:

/*
* Main.java
*/

package org.pisces;

import org.pisces.persist.SimpleManager;

/**
*
* @author kamhung
*/
publicclass Main {

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

2、 运行结果如下:
run:
连接数据库耗时: 1000毫秒
第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-1000:00:00.0, address
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值