我不是太懂,但是实在是急,说得对与错请您包含,只要点事例代码!
虽然我还没学EJB,但我在网上搜索到一堆关于这方面的问题及答案.......
三、建立数据库连接
EJB 容器维护数据库的连接池,这个连接池对 EJB 组件来说是透明的。当EJB 组件申请一个连接时,EJB 容器从连接池中提取一个连接并分配给组件。由于EJB 容器只是分配一个连接给 EJB 组件,所以组件很快就获得这个连接并连接数据库。数据库调用之后,组件就可以释放连接,这样它又可以快速申请到另一个连接。又因为一个组件只占用这个连接很短的时间,从而同一个连接可以被多个组件使用。
组件不是通过数据库的绝对名来连接数据库,而是用逻辑名连接到数据库, 即用 JNDI lookup 来获得数据库连接,例如:在下面例子中的AccountEJB 类中,连接数据库有以下几个步骤:
1、指定数据库的逻辑名:
private String dbName = "java:comp/env/jdbc/AccountDB";
2、获得数据源:
InitialContext ic = new InitialContext();
DataSource ds = (DataSource) ic.lookup(dbName);
3、从数据源得到数据库连接:
Connection con = ds.getConnection();
这种间接的连接数据库有以下几个优点:
· 可以在具有不同的数据库名的不同环境中部署相同的 EJB 组件。
· 可以在多个应用中重用EJB 组件。
· 可以集成 EJB 组件到运行在分布环境的应用系统中。
另外,EJB 规范没有要求 J2EE的实现支持某一个特别类型的数据库系统,因此EJB 组件可以连接到不同的数据库系统。