快速业务通道

浅析数据源在JDBC中的应用 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-24
rotocol, serverName,和databaseName属性将失效。

如果使用OCI驱动程序,并且networkProtocol属性被设定为ipc,除user和password外的所有其他属性将失效。

浅析数据源在JDBC中的应用(4)

时间:2010-03-27

通过JNDI使用数据源

在本节首先给出了一个实际程序,然后通过程序来讲解如何通过JNDI查询数据源。

import java.sql.*; import javax.sql.*; import oracle.jdbc.driver.*; import oracle.jdbc.pool.OracleDataSource; import javax.naming.*; import javax.naming.spi.*; import java.util.Hashtable; public class DataSourceJNDI { public static void main (String args []) throws SQLException { // 初始化名称服务环境 Context ctx = null; try { Hashtable env = new Hashtable (5); env.put (Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.fscontext.RefFSContextFactory"); env.put (Context.PROVIDER_URL, "file:JNDI"); ctx = new InitialContext(env); } catch (NamingException ne) { ne.printStackTrace(); } bind(ctx, "jdbc/chidb"); lookup(ctx, "jdbc/chidb"); } static void bind (Context ctx, String ln) throws NamingException, SQLException { // 创建一个OracleDataSource实例 OracleDataSource ods = new OracleDataSource(); ods.setDriverType("thin"); ods.setServerName("Chicago"); ods.setNetworkProtocol("tcp"); ods.setDatabaseName("chidb"); ods.setPortNumber(1521); ods.setUser("guest"); ods.setPassword("guest"); // 把OracleDataSource实例注册到JNDI中 System.out.println ("Doing a bind with the logical name : " + ln); ctx.bind (ln,ods); System.out.println ("Successfully bound"); } static void lookup (Context ctx, String ln) throws NamingException, SQLException { // 从JNDI中查询OracleDataSource实例 System.out.println ("Doing a lookup with the logical name : " + ln); OracleDataSource ods = (OracleDataSource) ctx.lookup (ln); System.out.println ("Successful lookup"); // 从查询到的OracleDataSource实例中获取数据库连接   Connection conn = ods.getConnection();   // 进行数据库操作 getUserName(conn); // 关闭连接 conn.close(); conn = null; } static void getUserName(Connection conn) throws SQLException { // 生成一个Statement实例 Statement stmt = conn.createStatement (); // 从addressbook表中选中姓名列 ResultSet rset = stmt.executeQuery ("select NAME from addressbook"); // 列出addressbook表所有人的姓名 while (rset.next ()) System.out.println ("Name is " + rset.getString (1)); // 关闭RseultSet实例 rset.close(); rset = null; // 关闭Statement实例 stmt.close(); stmt = null; } }

程序首先生成了一个Context实例。javax.naming.Context接口定义了名称服务环境(Naming Context)及该环境支持的操作。名称服务环境实际上是由名称和对象间的相互映射组成。程序中初始化名称服务环境的环境工厂(Context Factory)是com.sun.jndi.fscontext.RefFSContextFactory(该类在fscontext.jar中可以找到,由于fscontext.jar中包含的不是标准的API,用户需要从www.javasoft.com中的JNDI专区下载一个名为fscontext1_2beta3.zip的压缩文件,在该文件中可以找到fscontext.jar)。环境工厂的作用是生成名称服务环境的

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号