大家!
一段时间以来,我一直在努力寻找答案,但没有成功。
我尝试使用 Enterprise Java Beans 配置我的应用程序并使其在 JBoss Application Server 7.1.1 下运行。我的应用程序是 Web 应用程序,它使用 servlet 并将其他类作为 EJB 注入。问题是每个语句都被提交,这意味着不支持事务管理。
在我的测试示例中,我有一个包含一组子项的实体(映射为关系 OneToMany 和属性 CascadeType.ALL)。如果集合中的记录有问题(例如不存在的外键),它不能插入到表中并抛出异常。但是,父实体被插入,所以我假设插入是在不同的单独事务中完成的。这完全是不受欢迎的行为,我试图解决它。
技术参数:
数据库管理系统:Oracle EE 11g
AS:JBoss AS 7.1.1
我的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/">
<persistence-unit name="OracleEntityManager">
<jta-data-source>java:jboss/CmaDevDS</jta-data-source>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.Oracle9iDialect" />
<property name="hibernate.hbm2ddl.auto" value="none" />
<property name="hibernate.jdbc.batch_size" value="20" />
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.format_sql" value="true" />
<property name="hibernate.use_sql_comments" value="true" />
</properties>
</persistence-unit>
</persistence>
我的EJB:
@Stateless(name="EntityWriter")
@TransactionManagement(TransactionManagementType.CONTAINER)
public class EntityWriter {
@Resource
private SessionContext context;
/*@Resource
UserTransaction ut;*/
@PersistenceContext(unitName = "OracleEntityManager",type=PersistenceContextType.EXTENDED)
EntityManager em;
@TransactionAttribute(TransactionAttributeType.REQUIRED)
public EntityMarker insertEntity(EntityMarker entity)throws Exception
{
try
{
entity = em.merge(entity);
em.flush();
return entity;
}
catch (Exception e)
{
context.setRollbackOnly();
e.printStackTrace();
return null;
}
}
}
实际上,我尝试了两种 EJB 方法:Container Management Transaction 和 Bean Management Transaction,但都没有像我预期的那样工作。
当我将 bean 注入 servlet 时,我会这样做:
@EJB(name = "EntityWriter")
private EntityWriter entityWriter;
现在我认为 bean 很好,可能persistence.xml 中缺少一些东西。
将不胜感激任何想法。提前致谢!