一、在WebLogic新建针对Oracle数据库的JNDI数据源

点击左侧【 域结构】→【base domain】→【服务】→【数据源】然后点击右侧【新建】→【般数据源】,如下图所示:

填写JDBC数据源的【名称】、【jndi名称】,选择数据库类型,如选择【oracle】,下一步

选择Oracle数据库的驱动程序,如下图所示:

这里选择【Oracle' s Driver (Thin)for Instance connections;Version:Any】,点击【下一步】按钮,进入下一个配置步骤:

这里使用默认配置即可 ,点击【下一步】按钮,进入下一个配置步骤:如下图所示:

填写数据库的连接信息:要连接的数据库,数据库的IP地址,连接数据库时使用的端口号,登录数据库时使用的用户名和密码

点击【下一步】按钮,进入下一个配置步骤:如下图所示:

连接测试结果如下:

点击【下一步】按钮,进入下一个配置步骤:如下图所示:

点击【完成】,这样WebLogic就会创建一个新的JDBC数据源,如下图所示:

到此,在WebLogic新建针对Oracle数据库的JNDI数据源就算是全部完成了。数据源创建之后,我们就可以在应用程序中使用数据源了。

二、在WebLogic新建针对MySQL数据库的JNDI数据源

上面我们已经配置好了一个针对Oracle数据库的JNDI数据源,这里我们在新建一个针对MySQL数据库的数据源,配置步骤和上述针对Oracle数据库创建的JDBC数据源大部分是一样的,针对不一样的地方给出如下的截图说明:

到此,在WebLogic新建针对MySQL数据库的JNDI数据源就算是全部完成了。查看jndi树,可以看到JNDI树上面挂载了两个数据源,如下图所示:

三、在应用程序中使用WebLogic配置JNDI数据源

3.1、创建测试项目

新建一个测试项目,如下图所示:

3.2、编写测试代码

编写一个WebLogicJndiUtil工具类,用于从WebLogic的JNDI容器中取出数据源。

WebLogicJndiUtil工具类代码如下:

/**

*

*/

package me.gacl.util;

import java.sql.Connection;

import java.sql.SQLException;

import java.util.Properties;

import javax.naming.Context;

import javax.naming.InitialContext;

import javax.sql.DataSource;

/**

*

ClassName: WebLogicJndiUtil

*

Description: 获取WebLogic服务器中的JNDI数据源工具类

* @author xudp

* @version 1.0 V

* @createTime 2015-1-4 下午03:54:39

*/

public class WebLogicJndiUtil {

//初始化上下文需要用到的工厂类

private final static String INITIAL_CONTEXT_FACTORY="weblogic.jndi.WLInitialContextFactory";

//WebLogic服务器的访问地址

private final static String PROVIDER_URL="t3://192.168.1.144:7001";

//WebLogic服务器中的JNDI数据源名称

private final static String ORACLE_JNDI_NAME="JNDI/OracleDataSource";

private final static String MYSQL_JNDI_NAME="JNDI/MysqlDataSource";

//存储从JNDI容器中取出来的数据源

private static DataSource dsOracle = null;

private static DataSource dsMySQL = null;

static {

try {

//初始化WebLogic Server的JNDI上下文信息

Context context = getInitialContext();

//获取数据源对象

dsOracle = (DataSource) context.lookup(ORACLE_JNDI_NAME);

dsMySQL = (DataSource) context.lookup(MYSQL_JNDI_NAME);

} catch (Exception e) {

e.printStackTrace();

}

}

/**

* MethodName: getInitialContext

* Description: 获得WebLogic ServerJNDI初始上下文信息

* @author xudp

* @return

* @throws Exception

*/

private static Context getInitialContext() throws Exception {

Properties properties = new Properties();

properties.put(Context.INITIAL_CONTEXT_FACTORY, INITIAL_CONTEXT_FACTORY);

properties.put(Context.PROVIDER_URL, PROVIDER_URL);

return new InitialContext(properties);

}

/**

* MethodName: getOracleConnection

* Description: 获取Oracle数据库连接

* @author xudp

* @return

* @throws SQLException

*/

public static Connection getOracleConnection() throws SQLException {

return dsOracle.getConnection();

}

/**

* MethodName: getMySQLConnection

* Description: 获取MySQL数据库连接

* @author xudp

* @return

* @throws SQLException

*/

public static Connection getMySQLConnection() throws SQLException {

return dsMySQL.getConnection();

}

}

编写一个测试Servlet,JndiTestServlet的代码如下:

package me.gacl.test;

import java.io.IOException;

import java.sql.Connection;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import me.gacl.util.WebLogicJndiUtil;

/**

*

ClassName: JndiTestServlet

*

Description:

* @author xudp

* @version 1.0 V

* @createTime 2015-1-4 下午03:37:53

*/

public class JndiTestServlet extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

//Oracle数据库连接对象

Connection oracleConn = null;

//MySQL数据库连接对象

Connection mysqlConn = null;

Statement stmt = null;

ResultSet rs = null;

try {

String sqlOracle = "SELECT * FROM LEAD_OAMS_APPLICATIONS";

//获取数据库连接对象

oracleConn = WebLogicJndiUtil.getOracleConnection();

stmt = oracleConn.createStatement();

rs = stmt.executeQuery(sqlOracle);

while (rs.next()) {

System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("APP_NAME"));

}

System.out.println("-----------------------------分割线-------------------------------------");

String sqlMySQL = "SELECT * FROM LEAD_OAMS_DBSOURCES";

//获取数据库连接对象

mysqlConn = WebLogicJndiUtil.getMySQLConnection();

stmt = mysqlConn.createStatement();

rs = stmt.executeQuery(sqlMySQL);

while (rs.next()) {

System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("DBSOURCE_NAME"));

}

} catch (SQLException e) {

e.printStackTrace();

}finally{

try {

rs.close();

stmt.close();

oracleConn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

doGet(request,response);

}

}

在Web.xml文件中注册JndiTestServlet,如下:

JndiTestServlet

me.gacl.test.JndiTestServlet

JndiTestServlet

/servlet/JndiTestServlet

将测试项目部署到WebLogic服务器中运行,如下图所示:

输入JndiTestServlet的访问地址:http://localhost:7001/WebLogic_Jndi_Test/servlet/JndiTestServlet进行测试,如下图所示:

访问JndiTestServlet的过程中没有出现任何错误,后台的控制台中输出了从数据库中取出来的数据,如下图所示:

这就证明了我们已经成功地从WebLogic服务器中的JNDI树中取出了JDBC数据源,再通过数据源获取到了数据库连接,执行SQL从数据库中查询出数据。

以上就是关于在WebLogic配置JNDI数据源以及如何在应用程序中使用配置好的JNDI数据源的全部内容。

jndi weblogic mysql_在WebLogic新建针对Oracle数据库的JNDI数据源相关推荐

  1. 如何新建一个oracle数据库,ORACLE怎么新建数据库

    新建Oracle数据库三种方法: 1.通过运行Oracle Database Configuration Assistant 创建配置或删除数据库(也可在命令行下输入dbca): 2.用命令行的方式建 ...

  2. lsm mysql_基于LSM树的Oracle数据库数据处理方法与流程

    本发明涉及一种数据处理方法,尤其涉及一种基于LSM树的Oracle数据库数据处理方法. 背景技术: 数据库有三种基本的存储方式:1.哈希表,支持增.删.改以及随机读取操作,但不支持顺序扫描,对应的存储 ...

  3. sql+plus远程连接mysql_设置sqlplus访问远程oracle数据库的方法

    如果要连接远程数据库,传统的一定可行的方法是在本地装一个oracle,然后使用"Network Configuration Assistant"配置,之后用PL/SQL Dev连接 ...

  4. 针对Oracle数据库优化策略

    一.Oracle数据库系统安装配置及基础优化 操作系统安装 操作交换区 交换区是Oracle的一项基本的要求.可以根据Oracle的发行要求来确定.一般交换区大小的要求是该服务器内存的2倍至4倍之间. ...

  5. teradata查看正在运行的进程_goldengate 进程在oracle数据库哪个视图

    展开全部 Oracle GoldenGate 用于在各种企业系统间以亚秒级速度复制和集成事务数据,是同类最佳的32313133353236313431303231363533e4b893e5b19e3 ...

  6. TSM对Oracle数据库备份脚本

    TSM在实现对Oracle数据库的备份时,实际上是调用RMAN工具来完成的,为了使后期备份检查更加方便,在此介绍下我经常使用的一些方式: 1.编写bak_full.sh脚本文件,主要为针对Oracle ...

  7. 在.NET开发面向Oracle数据库的应用程序

    其实这个不是一个什么新的话题.但是之前在多次项目中,总是遇到大家针对Oracle数据库的访问时,会有各种各样的问题,最基本的就是要在客户端安装各种client,版本不一样的话还有各种问题. 静下心来看 ...

  8. oracle数据库没有选项,创建oracle数据库时,出现ORA-00922: 选项缺失或无效

    sdd53HOME 新建oracle数据库时遇到ORA-00922: 选项缺失或无效的问题,如图: 原因:一般是语句的语法有问题.比如命名不对,关键字写错等等.对于非标准的命名,一般采用双引号来创建. ...

  9. oracle集群数据库事务配置,在 .NET中使用Oracle数据库事务-安装配置-Oracle频道-中国IT实验室...

    在本文中,您将了解到如何在 Visual Basic .NET (VB.NET) 和 Visual .NET () 中使用数据库事务.具体来讲,您将系统学习数据库事务.在 .NET 程序中使用 Tra ...

最新文章

  1. 【Java常识】7.0 数组实现冒泡排序、选择排序和二分查找
  2. 学习机器学习,究竟是理论重要,还是公式推导重要?
  3. SQL Server 批量完整备份
  4. java多附件上传 实例demo
  5. opsforhash 过期时间_药品过期还能吃吗?本文带你秒懂药品有效期~
  6. 使用Android应用调用WebService实现天气预报
  7. linux上听FM程序,安装和使用Odio在Linux上收听FM收音机的方法
  8. 这是可用于下一个项目的React Native工具列表
  9. idea中tomcat服务器的配置
  10. ListView上拉加载,下拉刷新 PullToRefresh的使用
  11. linux nsf 扫描,linux 使用NSF 映射远程磁盘目录的实现
  12. [BZOJ3944]Sum
  13. 【NOIP2017】李电下棋
  14. 台电固态硬盘用什么测试软件,常规测试、实际使用测试与总结_固态硬盘评测-中关村在线...
  15. 我解决了net framework 4安装失败,提示找不到指定文件的问题
  16. iOS开发 语音合成支持后台和锁屏情况
  17. 搭建ASP环境-win7安装IIS并运行ASP程序
  18. 局域网自定义域名H5站点移动设备测试时的代理设置
  19. AJAX 请求 NIDE 搭建简单服务
  20. iTutorGroup学员获2018全国青少年创意编程大赛一等奖

热门文章

  1. 定义结构体时的初始化默认值
  2. 华为交换机关闭服务端口
  3. SPIN Routing Algorithm
  4. 如何设置自定义任务栏图标_如何为任何应用程序自定义Windows 7任务栏图标
  5. 数据看板--日报、周报、月报
  6. HashMap源码阅读启读
  7. 极客巅峰2021 web opcode
  8. antd表格分页控件显示英文page
  9. svn多分支合并主干冲突 svn Working copy and merge source not ready for reintegration
  10. android界面不显示,Android 可视化界面编辑器无法显示界面问题的终极解决方案