JPA 从数据库中检索对象
JPA retrieve objects from database
我正在尝试解决大学的 Java 编程练习,但我不知道如何解决下一个问题。我有下一个 persistence.xml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.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="stud" transaction-type="RESOURCE_LOCAL">
<class>lt.vu.mif.jate.tasks.task03.jpa.model.Customer</class>
<class>lt.vu.mif.jate.tasks.task03.jpa.model.Product</class>
<class>lt.vu.mif.jate.tasks.task03.jpa.model.Sale</class>
<exclude-unlisted-classes>true</exclude-unlisted-classes>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"/>
<property name="hibernate.max_fetch_depth" value="3"/>
<property name="hibernate.cache.provider_class" value="net.sf.ehcache.hibernate.NoCacheProvider"/>
<property name="hibernate.generate_statistics" value="false"/>
<property name="javax.persistence.jdbc.url" value="jdbc:postgresql://****************"/>
<property name="javax.persistence.jdbc.user" value=""/>
<property name="javax.persistence.jdbc.password" value=""/>
<property name="javax.persistence.jdbc.driver" value="org.postgresql.Driver"/>
<property name="hibernate.hbm2ddl.auto" value="none"/>
</properties>
</persistence-unit>
</persistence>
数据库的URL此处省略。我无法更改此文件。我必须连接到数据库并从数据库中获取所有数据。我已经创建了所需的三个 类。我该怎么做?非常感谢。
看看这个页面:
http://www.oracle.com/webfolder/technetwork/tutorials/obe/java/SettingUpJPA/SettingUpJPA.htm
和
https://docs.jboss.org/hibernate/orm/3.6/quickstart/en-US/html/hibernate-gsg-tutorial-jpa.html
还有其他一些教程等。但我认为你缺少的关键部分是:
public static void main(String[] args) {
EntityManagerFactory emf = Persistence.createEntityManagerFactory("stud");
EntityManager em = emf.createEntityManager();
}
这为您提供了一个 EntityManager。然后你可以调用:
em.getTransaction().begin();
List<Customer> result = entityManager.createQuery( "from Customer", Customer.class ).getResultList();
我正在尝试解决大学的 Java 编程练习,但我不知道如何解决下一个问题。我有下一个 persistence.xml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.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="stud" transaction-type="RESOURCE_LOCAL">
<class>lt.vu.mif.jate.tasks.task03.jpa.model.Customer</class>
<class>lt.vu.mif.jate.tasks.task03.jpa.model.Product</class>
<class>lt.vu.mif.jate.tasks.task03.jpa.model.Sale</class>
<exclude-unlisted-classes>true</exclude-unlisted-classes>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"/>
<property name="hibernate.max_fetch_depth" value="3"/>
<property name="hibernate.cache.provider_class" value="net.sf.ehcache.hibernate.NoCacheProvider"/>
<property name="hibernate.generate_statistics" value="false"/>
<property name="javax.persistence.jdbc.url" value="jdbc:postgresql://****************"/>
<property name="javax.persistence.jdbc.user" value=""/>
<property name="javax.persistence.jdbc.password" value=""/>
<property name="javax.persistence.jdbc.driver" value="org.postgresql.Driver"/>
<property name="hibernate.hbm2ddl.auto" value="none"/>
</properties>
</persistence-unit>
</persistence>
数据库的URL此处省略。我无法更改此文件。我必须连接到数据库并从数据库中获取所有数据。我已经创建了所需的三个 类。我该怎么做?非常感谢。
看看这个页面:
http://www.oracle.com/webfolder/technetwork/tutorials/obe/java/SettingUpJPA/SettingUpJPA.htm
和
https://docs.jboss.org/hibernate/orm/3.6/quickstart/en-US/html/hibernate-gsg-tutorial-jpa.html
还有其他一些教程等。但我认为你缺少的关键部分是:
public static void main(String[] args) {
EntityManagerFactory emf = Persistence.createEntityManagerFactory("stud");
EntityManager em = emf.createEntityManager();
}
这为您提供了一个 EntityManager。然后你可以调用:
em.getTransaction().begin();
List<Customer> result = entityManager.createQuery( "from Customer", Customer.class ).getResultList();