Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/design-patterns/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 如何在jpa中创建会话和激发查询_Java_Hibernate_Jpa - Fatal编程技术网

Java 如何在jpa中创建会话和激发查询

Java 如何在jpa中创建会话和激发查询,java,hibernate,jpa,Java,Hibernate,Jpa,我是JPA2.0的新手。 有人能告诉我如何创建一个新会话,然后在JPA中执行查询的步骤吗 请执行必要的操作。我希望您已经创建了一个带有持久性单元标记的persistence.xml。如果你没有,那么你需要一个,这里就是一个例子 <?xml version="1.0" encoding="UTF-8"?> <persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi=

我是JPA2.0的新手。 有人能告诉我如何创建一个新会话,然后在JPA中执行查询的步骤吗


请执行必要的操作。

我希望您已经创建了一个带有持久性单元标记的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_2_0.xsd">
    <persistence-unit name="JPASamplePU" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <class>org.cksoft.jpasample.entity.Person</class>
        <class>org.cksoft.jpasample.entity.Profile</class>
        <class>org.cksoft.jpasample.entity.Department</class>
        <class>org.cksoft.jpasample.entity.Skills</class>
        <properties>
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" />
            <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/MyApp_DB" />
            <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" />
            <property name="hibernate.connection.username" value="root" />
            <property name="hibernate.connection.password" value="" />
            <property name="hibernate.show_sql" value="true" />
            <property name="hibernate.format_sql" value="true" />
            <property name="hibernate.hbm2ddl.auto" value="update" />
            <!-- <property name="hibernate.cache.use_second_level_cache" value="true" 
                /> -->
            <!-- <property name="hibernate.cache.use_query_cache" value="true" /> -->
        </properties>
    </persistence-unit>
</persistence>
下面是我们如何获取事务并开始它并提交它的方法

em.getTransaction().begin(); 
em.getTransaction().commit();
在此之后,您可以继续使用EntityManager或关闭它

em.close();
会话是特定于hibernate的类,它几乎与EntityManager相同。
伙计们,如果我错了或者缺少了什么,请纠正我。谢谢。

我有一个实体管理器对象,但我的问题是如何创建一个新会话,然后启动查询并关闭会话。我认为您要的是打开和关闭它的事务,对吗?EntityManager em=emf.createEntityManager();创建新会话还是现有会话?我需要创建一个新的会话。它为您提供了一个新的entityManager,而不是会话。您可以使用同一entitymanager执行不同的事务感谢您提供的信息,但在我的应用程序中,需要创建一个新会话,以使用AuditLoginInterceptor审核插入/更新/删除事务。
em.close();