扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
作者:中国IT实验室 来源:中国IT实验室 2007年9月30日
关键字:
在本页阅读全文(共4页)
??二,开发EJB应用
如果开发EJB应用,建议采用JBoss作为开发服务器,因为开发、调试、部署速度快。如果采用其他商用服务器,由于实现机理的不同,其编译的速度很慢。
如果采用Entity Beans技术,则您需要知道这么几点。第一,您目标系统的数据源有多少个操作入口,即是否存在Entity Beans之外的方式来操作数据库。如果有,则需要调节相应< container-name >的< commit-option >提交策略以及< locking-policy >策略。
比如,JBoss 3.2.1采用的< commit-option >方式有4种:A、B、C、D。当然,如果除了Entity Beans访问数据库外,别无它出,采用A是很理智的。如果有,则需要取决于具体的情况使用< commit-option >方式。同时,< commit-option >方式的选择与< locking-policy >策略有关系。
能够采用< read-only >的Entity Beans或Entity Beans Methods,则尽量采用,这样会减少或消除死锁发生的可能性。
尽量采用1:n的关系来操作n方的数据表结构,这样能够提高EJB Container的效率。
其中,本文重点给出EJB事务处理方面的探讨。
一般情况下,J2EE应用服务器支持JDBC事务、JTA事务、容器管理事务。同时,最好不要在程序中同时使用上述三种事务类型,比如在JTA事务中嵌套JDBC事务;第二方面,事务要在尽可能短的时间内完成,不要在不同方法中实现事务的使用。比如,下面给出了回滚JDBC事务的代码示例:
??public void processT(String orders) { ???Context initCtx = new InitialContext(); ???javax.sql.DataSource ds = javax.sql.DataSource)initCtx.lookup("java:comp/env/jdbc/OrdersDB"); ???java.sql.Connection conn = ds.getConnection(); ???try{ ????conn.setAutoCommit( false ); // 更改JDBC事务的默认提交方式 ????orderNo = createOrder( orders ); ????updateOrderStatus(orderNo, "orders created"); ????conn.commit(); // 提交JDBC事务 ???}catch( Exception e ){ ????try{ ?????conn.rollback(); // 回滚sJDBC事务 ?????throw new EJBException("事务回滚:" + e.getMessage()); ????}catch( SQLException sqle ){ ?????throw new EJBException("出现SQL操作错误:" + sqle.getMessage()); ????} ???} ??} |
??public void processOrder(String orderMessage) { ???UserTransaction transaction = mySessionContext.getUserTransaction();// 获得JTA事务 ???try{ ????transaction.begin(); // 开始JTA事务 ????orderNo = sendOrder(orderMessage); ????updateOrderStatus(orderNo, "order sent"); ????transaction.commit(); // 提交JTA事务 ????}catch(Exception e){ ?????try{ ??????transaction.rollback();// 回滚JTA事务 ?????}catch(SystemException se){ ??????se.printStackTrace(); ?????} ????throw new EJBException("事务回滚:" + e.getMessage()); ???} ??} |
??(修改自,Transactions in J2EE(RedBooks).pdf中的一段Bean管理的JTA事务)
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。