Jboss通过数据源连接Oracle

配置Jboss访问Oracle数据库[@more@]

Jboss通过数据源连接Oracle

1. Jboss服务进程的Oracle数据源配置及部署

Jboss的安装路径为$Jboss,首先在路径$Jbossserverdefaultlib路径下放置连接数据库所用的JDBC Driverojdbc14.jar,然后在路径$Jbossserverdefaultdeploy下,创建Oracle数据源文件oracle-ds.xml,该文件需指明:

ü jndi-name:数据源的jndi名称

ü connection-url:数据库连接串,参照所访问数据库的TNS配置

ü user-name:访问数据库的用户名

ü password:访问数据库的用户密码

ü driver-classexception-sorter-class-namemetadata保留原样

文件内容如下:

OracleDS

jdbc:oracle:thin:@127.0.0.1:1521:remorse

oracle.jdbc.OracleDriver

scott

tiger

org.jboss.resource.adapter.jdbc.vendor.OracleExceptionSorter

Oracle9i

2. 应用引用Oracle数据源

应用引用数据源有两种方式,一种为直接进行JNDI名称查找,另一种使用资源引用方式,即应用使用某资源引用,而部署人员进行资源引用与JNDI所代表资源的映射。由于资源引用方式便于部署,故两种方式中推荐使用资源引用方式。设待部署应用$db_test,其部署路径为$Jbossserverdefaultdeploydb_test.war,在该路径下创建JSP文件index.jsp,文件内容如下:

/* direct lookup the JNDI configured in oracle-ds.xml */

InitialContext ctx = new InitialContext();

DataSource ds = (DataSource) ctx.lookup("java:/OracleDS");

Connection conn = ds.getConnection();

--&gt

/* Lookup the reference, The reference should be defined in web.xml and jboss-web.xml */

InitialContext ctx = new InitialContext();

Context envCtx = (Context) ctx.lookup("java:comp/env");

DataSource ds = (DataSource) envCtx.lookup("jdbc/TestDB");

Connection conn = ds.getConnection();

Statement stmt = conn.createStatement();

ResultSet rs = stmt.executeQuery("SELECT TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SS') FROM DUAL");

while ( rs.next() ) {

out.println( rs.getString(1) + "
");

out.println( "Oracle Connection Test
");

}

conn.close();

Test Oracle Database

3. 部署应用

$Jbossserverdefaultdeploydb_test.warWEB-INF下创建两文件:jboss-web.xmlweb.xml,若使用直接查找JNDI的话,则两文件无有效内容,具体如下:

web.xml文件:

jboss-web.xml文件:

PUBLIC "-//JBoss//DTD Web Application 2.3V2//EN"

"http://www.jboss.org/j2ee/dtd/jboss-web_3_2.dtd">

若使用资源引用方式使用数据源,则具体如下:

web.xml文件:

DB Connection

jdbc/TestDB

javax.sql.DataSource

Container

jboss-web.xml文件:

PUBLIC "-//JBoss//DTD Web Application 2.3V2//EN"

"http://www.jboss.org/j2ee/dtd/jboss-web_3_2.dtd">

jdbc/TestDB

java:OracleDS

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/247757/viewspace-1006548/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/247757/viewspace-1006548/

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,您需要将Oracle JDBC驱动程序添加到JBoss 7。您可以按照以下步骤操作: 1. 下载适用于您的Oracle版本的JDBC驱动程序(通常是一个.jar文件)。 2. 将驱动程序文件复制到JBoss 7的“modules”目录中。例如,如果您使用的是Oracle 12c,您可以将驱动程序文件复制到“modules/system/layers/base/com/oracle/jdbc/main”目录中。 3. 在该目录中创建一个新的“module.xml”文件,并将以下内容添加到该文件中: ``` <?xml version="1.0" encoding="UTF-8"?> <module xmlns="urn:jboss:module:1.1" name="com.oracle.jdbc"> <resources> <resource-root path="ojdbc7.jar"/> <!--替换为您的驱动程序名称--> </resources> <dependencies> <module name="javax.api"/> <module name="javax.transaction.api"/> </dependencies> </module> ``` 4. 在JBoss 7的“standalone.xml”配置文件中,找到以下部分: ``` <drivers> ... </drivers> ``` 5. 添加以下内容: ``` <driver name="oracle" module="com.oracle.jdbc"> <driver-class>oracle.jdbc.driver.OracleDriver</driver-class> <xa-datasource-class>oracle.jdbc.xa.client.OracleXADataSource</xa-datasource-class> </driver> ``` 6. 现在,您可以在EJB 3.1中使用JNDI来访问您的Oracle数据库。您可以在您的应用程序中使用以下代码: ``` Context ctx = new InitialContext(); DataSource ds = (DataSource)ctx.lookup("java:jboss/datasources/MyOracleDS"); Connection conn = ds.getConnection(); ``` 其中,“MyOracleDS”是您在“standalone.xml”中定义的数据源的名称。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值