java - 如何使用 hibernate 设置 UserTransaction

标签 java mysql hibernate wildfly jta

我有一个用于管理用户信息的 mySQL 数据库,我正在为我的 mySQL 数据库使用 JTA 数据源,这是 persistence.xml 的样子:

<persistence 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"
             version="2.0">
   <persistence-unit name="SensorCloudPU" transaction-type="JTA">
      <jta-data-source>java:/SensorCloudPU</jta-data-source>
<!--      <non-jta-data-source>java:/SensorCloudPU</non-jta-data-source> -->
      <class>com.sensorhound.common.domain.impl.AnomalousInfo</class>
      <class>com.sensorhound.common.domain.impl.Code</class>
      <class>com.sensorhound.common.domain.impl.Device</class>
      <class>com.sensorhound.common.domain.impl.Executable</class>
      <class>com.sensorhound.common.domain.impl.Group</class>
      <class>com.sensorhound.common.domain.impl.GroupAlert</class>
      <class>com.sensorhound.common.domain.impl.GroupRule</class>
      <class>com.sensorhound.common.domain.impl.GroupRuleDefinition</class>
      <class>com.sensorhound.common.domain.impl.GroupRuleStatus</class>
      <class>com.sensorhound.common.domain.impl.Node</class>
      <class>com.sensorhound.common.domain.impl.NodeAlert</class>
      <class>com.sensorhound.common.domain.impl.NodeRule</class>
      <class>com.sensorhound.common.domain.impl.NodeRuleDefinition</class>
      <class>com.sensorhound.common.domain.impl.Organization</class>
      <class>com.sensorhound.common.domain.impl.PastGroupStatus</class>
      <class>com.sensorhound.common.domain.impl.Trace</class>
      <class>com.sensorhound.common.domain.impl.TrainingSession</class>
      <class>com.sensorhound.common.domain.impl.User</class>
      <class>com.sensorhound.common.domain.impl.Role</class>
      <exclude-unlisted-classes>true</exclude-unlisted-classes>
      <properties>
         <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>
         <property name="hibernate.hbm2ddl.auto" value="update"/>
         <property name="hibernate.show_sql" value = "false" />
         <property name="hibernate.connection.autocommit" value="true" />
         <property name="hibernate.event.merge.entity_copy_observer" value="allow"/>
         <property name="transaction.factory_class" value="org.hibernate.transaction.JTATransactionFactory"/>
         <property name="jta.UserTransaction" value="java:jboss/UserTransaction"/>
      </properties>
   </persistence-unit>
</persistence>

我有一个这样的端点:

@Path("/delete")
  @POST
  @Consumes(MediaType.APPLICATION_FORM_URLENCODED)
  @Produces(MediaType.APPLICATION_JSON)
  public Response deleteUser(@FormParam("organization_id") Integer organizationId,
      @FormParam("username") String username) throws JsonProcessingException, NotSupportedException,
      SystemException, SecurityException, IllegalStateException, RollbackException,
      HeuristicMixedException, HeuristicRollbackException, NamingException {
    Organization org = organizationDAO.getByOrganizationId(organizationId);
    userDao.deleteUserByUserNameAndOrganization(username, org);
    return Response.status(Response.Status.OK).build();
  }

DAO 是这样的:

public class userDAO {
  @PersistenceContext(unitName = "SensorCloudPU")
  protected EntityManager em;

  @Resource
  protected UserTransaction utx;

  public void deleteUserByUserNameAndOrganization(String userName, Organization org)
          throws NotSupportedException, SystemException, SecurityException, IllegalStateException,
          RollbackException, HeuristicMixedException, HeuristicRollbackException {
        Query q = this.em.createNamedQuery(User.Q_GET_BY_USERNAME_AND_ORGANIZATION);
        q.setParameter("organization", org);
        q.setParameter("user_name", userName);
        User u = this.executeQueryForSingleResult(q);
        if (u == null) {
          return;
        }
        utx.begin();
        this.em.remove(u);
        utx.commit();
      }
}

但每次当我加载页面并尝试从数据库中删除时,我都会收到此错误:

注入(inject)资源查找失败:java:jboss/UserTransaction]

UserTransaction [根异常是 java.lang.IllegalStateException: WFLYEJB0137: 只有具有 bean 管理事务划分的 session 和消息驱动 bean 才允许访问 UserTransaction]

最佳答案

您不能在 EJB 中使用 UserTransaction,除非您添加 @TransactionManagement(BEAN)

TransactionManagement 做的是

指定 session bean 或消息驱动的 bean 是否具有容器管理的事务或 bean 管理的事务。如果不使用此注释,则假定该 bean 具有容器管理的事务管理。

@TransactionManagement(BEAN)
public class userDAO {

关于java - 如何使用 hibernate 设置 UserTransaction,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45423923/

相关文章:

java - 将提供的依赖关系传播到依赖项目

c# - 如何在asp.net中使用mysql连接远程数据库?

java - 如何从字符串中删除某些特定单词并将其存储在临时变量中并将该变量发送到我的查询

hibernate - 动态添加新的typeAliases到hsqldb(inet和text)

java - 有没有办法通过 Hibernate 观察数据库表的变化?

java - 如何构建 EJB 的内容

java - Hibernate 为子类 dao 使用事务管理器

php - 错误语法mysql..将数组保存到数据库时

php - 使用多个分隔符/字段分隔符将 CSV 文件导入 Mysql

java - Spring Boot 和使用外部 Tomcat 进行日志记录