我正在使用ojdbc6-11.2.0.3.jar
,驱动程序在两种配置下都能正常工作。
我与JBoss的保险丝控制台
jdbc:query jdbc/oracle 'select * from somewhere.sometable WHERE rownum < 5'
检查JDBC和JNDI安装查询
features:install jdbc
features:install jndi
您可以用下面的内容放置一个XML文件到deploy/
,自动将已经测试了它部署了一个数据源。
OracleDataSource
<?xml version="1.0" encoding="UTF-8"?>
<blueprint xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0">
<bean id="oracleDSTest" class="oracle.jdbc.pool.OracleDataSource"
destroy-method="close">
<property name="URL" value="jdbc:oracle:thin:@db.host:1521:SID" />
<property name="user" value="UrName" />
<property name="password" value="YourPasswrd" />
</bean>
<service interface="javax.sql.DataSource" ref="oracleDSTest">
<service-properties>
<entry key="osgi.jndi.service.name" value="jdbc/oracle" />
<entry key="datasource.name" value="oracleDSTest" />
</service-properties>
</service>
</blueprint>
的BasicDataSource
<bean id="oracleDSTest" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@db.host:1521:SID"/>
<property name="username" value="UrName"/>
<property name="password" value="YourPasswrd"/>
<property name="maxIdle" value="5" />
<property name="minIdle" value="1" />
<property name="initialSize" value="1" />
</bean>
<service interface="javax.sql.DataSource" ref="oracleDSTest">
<service-properties>
<entry key="osgi.jndi.service.name" value="jdbc/oracle" />
<entry key="datasource.name" value="oracleDSTest" />
</service-properties>
</service>
类加载
请英里nd此版本的Oracle JDBC驱动程序是而不是 OSGi已准备就绪。 为了让所有东西都能在OSGi下运行,您可能需要从 系统软件包中导出Oracle类。
复制ojdbc6-11.2.0.3.jar
(或您的版本)到JBoss Fuse的lib/
文件夹。
编辑etc/config.properties
和软件包添加到org.osgi.framework.system.packages
财产
org.osgi.framework.system.packages= \
other.packages.here, \
oracle.jdbc;version="11.2.0.3", \
oracle.jdbc.driver;version="11.2.0.3", \
oracle.jdbc.pool;version="11.2.0.3", \
some.other.stuff
重新启动,并与exports | grep oracle
JBossFuse:[email protected]> exports | grep oracle
0 oracle.jdbc; version=11.2.0.3
0 oracle.jdbc.driver; version=11.2.0.3
0 oracle.jdbc.pool; version=11.2.0.3
检查Oracle罐子哪个版本您使用的? –
ojdbc(11.2.0.0) – muru
我花了一些时间来检查:我的机器上一切正常。尽管我使用的是稍微不同的版本。 –