jboss中通过JNDI得到数据源

在ZTE中兴做项目的时候,一会换Oracle,一会换Sysbase,配置文件也在不换的换,底层获取连接的代码感觉很复杂。但是
在jboss中通过JNDI得到数据源也就主要是这样实现

先来介绍两个基本概念:

1. 数据源和连接池.

在 DataSoure 中可以事先建立多个数据源对象,把这些数据库连接保存在连接池( Context poo) 中.这样我们在访问数据库时,不用自己再手动创建数据库连接,直接在连接池中捞一个数据库连接对象即可.如果这时连接池中没有可用的连接时,客户程序就将等待.

这样的好处:1)避免客户程序每次访问数据库都创建数据库连接,提高程序相应时间.
2)避免数据库连接这样的稀缺资源因无法回收被常时间占有.

2. 数据源和 JNDI 资源

DataSource 对象是由 JBoss 提供的,不能在程序中用创建实例的方式获得 DataSource 对象.而需要采用 JNDI ( java naming and directory interface )技术,来获得 DataSource 对象的引用.其实 JNDI 简单来讲就是一种将对象和名称绑定的技术. Javax.naming 包中提供 Context 接口,该接口提供将对象和名字绑定.

下面就来具体备置一下数据源: (以 Mysql 为例.数据库名称: test  用户名 :root 密码为空)

* 在 JBoss 目录\ docs\examples\jca 下提供了各种数据库的备置文件格式.该目录下找到 mysql-ds.xml 文件.
* 把 mysql-ds.xml 拷贝到 JBoss 目录\ server\default\deploy 下

* 打开 mysql-ds.xml 文件.修改如下

1 < local-tx-datasource >
2 < jndi-name > TestDS </ jndi-name >
3 < connection-url > jdbc:mysql://localhost:3306/test?useUnicode=true & characterEncoding=UTF-8 </ connection-url >
4 < driver-class > com.mysql.jdbc.Driver </ driver-class >
5 < user-name > root </ user-name >
6 < password ></ password >
7 </ local-tx-datasource >

* 保存.
* 在java程序中得到数据源.代码如下:

1
   public Connection getConnection() throws Exception {
2 Context cnt = new InitialContext();
3 DataSource ds = (DataSource)cnt.lookup( " java:/TestDS " );
4 return ds.getConnection();
5 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值