1. 使用maven创建一个jpa的测试工程
<textarea cols="50" rows="15" name="code" class="python">mvn archetype:create -DgroupId=myjpa -DartifactId=myjpa</textarea>
2. 添加jpa所依赖的包
<textarea cols="50" rows="15" name="code" class="xhtml"> <build> <plugins> <plugin> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.5</source> <target>1.5</target> </configuration> </plugin> </plugins> </build> <repositories> <repository> <id>EclipseLink Repo</id> <url>http://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/rt/eclipselink/maven.repo </url> </repository> </repositories> <dependencies> <dependency> <groupId>commons-lang</groupId> <artifactId>commons-lang</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>org.eclipse.persistence</groupId> <artifactId>javax.persistence</artifactId> <version>2.0.0</version> </dependency> <dependency> <groupId>org.eclipse.persistence</groupId> <artifactId>eclipselink</artifactId> <version>2.0.0</version> </dependency> <dependency> <groupId>hsqldb</groupId> <artifactId>hsqldb</artifactId> <version>1.8.0.7</version> </dependency> <dependencies></textarea>
3. 创建两个model类
Customer.java
<textarea cols="50" rows="15" name="code" class="java">package myjpa.model; import java.io.Serializable; import java.util.ArrayList; import java.util.Date; import java.util.List; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.OneToMany; import javax.persistence.Temporal; import javax.persistence.TemporalType; @Entity public class Customer implements Serializable { private static final long serialVersionUID = 1L; @Id @GeneratedValue(strategy = GenerationType.TABLE) private int id; private String name; private String email; @Temporal(TemporalType.DATE) private Date birthday; @OneToMany(mappedBy = "customer") private final List<Address> addresses = new ArrayList<Address>(); public int getId() { <mce:script type="text/javascript" src="http://hi.images.csdn.net/js/blog/tiny_mce/themes/advanced/langs/zh.js" mce_src="http://hi.images.csdn.net/js/blog/tiny_mce/themes/advanced/langs/zh.js"></mce:script><mce:script type="text/javascript" src="http://hi.images.csdn.net/js/blog/tiny_mce/plugins/syntaxhl/langs/zh.js" mce_src="http://hi.images.csdn.net/js/blog/tiny_mce/plugins/syntaxhl/langs/zh.js"></mce:script>return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public List<Address> getAddresses() { return addresses; } public void addAddress(Address address) { this.addresses.add(address); address.setCustomer(this); } @Override public String toString() { return org.apache.commons.lang.builder.ToStringBuilder.reflectionToString(this); } }</textarea>
Address.java
<textarea cols="50" rows="15" name="code" class="java">package myjpa.model; import java.io.Serializable; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.ManyToOne; @Entity public class Address implements Serializable { private static final long serialVersionUID = 1L; @Id @GeneratedValue(strategy = GenerationType.TABLE) private int id; private String name; private String description; private String zipcode; @ManyToOne private Customer customer; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } public String getZipcode() { return zipcode; } public void setZipcode(String zipcode) { this.zipcode = zipcode; } @ManyToOne public Customer getCustomer() { return customer; } public void setCustomer(Customer customer) { this.customer = customer; } @Override public String toString() { return org.apache.commons.lang.builder.ToStringBuilder.reflectionToString(this); } }</textarea>
4. 配置persistence.xml文件
在工程的src/main/resources目录下创建META-INF目录,并在META-INF下创建persistence.xml文件,内容如下:
<textarea cols="50" rows="15" name="code" class="xhtml"> <?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"> <persistence-unit name="eclipselink"> <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider> <class>myjpa.model.Customer</class> <class>myjpa.model.Address</class> <properties> <property name="javax.persistence.jdbc.driver" value="org.hsqldb.jdbcDriver" /> <property name="javax.persistence.jdbc.url" value="jdbc:hsqldb:mem:." /> <property name="javax.persistence.jdbc.user" value="sa" /> <property name="javax.persistence.jdbc.password" value="" /> <property name="eclipselink.ddl-generation" value="drop-and-create-tables" /> <property name="eclipselink.ddl-generation.output-mode" value="database" /> </properties> </persistence-unit> </persistence></textarea>
5. 编写测试类
<textarea cols="50" rows="15" name="code" class="java">package myjpa; import java.util.Calendar; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.Persistence; import javax.persistence.TypedQuery; import myjpa.model.Address; import myjpa.model.Customer; public class Test { public static void main(String[] args) throws Exception { EntityManagerFactory factory = Persistence.createEntityManagerFactory("eclipselink"); EntityManager em = factory.createEntityManager(); em.getTransaction().begin(); for (int i = 0; i < 10; i++) { Customer customer = new Customer(); customer.setName("customer" + i); customer.setEmail("customer" + i + "@my.com"); customer.setBirthday(Calendar.getInstance().getTime()); Address addressHome = new Address(); addressHome.setName("Home"); addressHome.setDescription("Home"); addressHome.setZipcode("123456"); em.persist(addressHome); Address addressOffice = new Address(); addressOffice.setName("Office"); addressOffice.setDescription("Office"); addressOffice.setZipcode("654321"); em.persist(addressOffice); customer.addAddress(addressHome); customer.addAddress(addressOffice); em.persist(customer); } em.getTransaction().commit(); em.close(); em = factory.createEntityManager(); TypedQuery<Customer> q = em.createQuery("select c from Customer c", Customer.class); List<Customer> customers = q.getResultList(); for(Customer c: customers) { System.out.println(c); } em.close(); } } </textarea>
6. 运行测试类,JPA会自动创建所要使用的数据库和表,然后就会执行相应的添加和查询操作。