JNDI和JDBC的区别和联系及其使用方法
一.JNDI 和JDBC的区别和联系
两者都是API,是连接数据库的标准。并不是什么产品或方法。
二.JDBC
全称:Java Database Connectivity
以一种统一的方式来对各种各样的数据库进行存取
使用JDBC带来的问题:
(1).数据库服务器名称 、用户名和口令都可能需要改变,由此引发JDBC URL需要修改
(2).数据库可能改用别的产品,如改用DB2或者Oracle,引发JDBC驱动程序包和类名需要修改
(3).随着实际使用终端的增加,原配置的连接池参数可能需要调整
使用方法:
(1)加载数据库驱动,填写数据库url,用户名,密码
(2)在程序中进行调用
三.JNDI
Java
Naming and Directory Interface
它提供了一致的模型来存取和操作企业级的资源如DNS和LDAP
JNDI相对与JDBC来说是他的灵活性,程序员不需要关心“具体的数据库后台是什么?JDBC驱动程序是什么?JDBC URL格式是什么?访问数据库的用户名和口令是什么?”等等这些问题,程序员编写的程序应该没有对 JDBC 驱动程序的引用,没有服务器名称,没有用户名称或口令 —— 甚至没有数据库池或连接管理。而是把这些问题交给J2EE容器来配置和管理,程序员只需要对这些配置和管理进行引用即可。
使用方法:
tomcat下jndi的两种配置方式
(一).非全局的JNDI配置:只针对某一个Web项目的数据源的配置
1.导入要链接数据库的jar包文件
例如:
sqlserver导入:sqljdbc4.jar包
oracle导入:ojdbc14.jar包
mySQL导入:mysql-connector-java-5.0.8.jar包
2.在JNDI中配置数据库的连接池
在WEB项目中的META-INF中创建一个context.xml文件。用于设置数据库的连接池信息
例如(mysql):
<?xml version="1.0" encoding="UTF-8"?>
<Context>
<!--
JNDI数据源配置
J2EE服务器上保存着一个数据库的多个连接(连接池中),
数据源被绑定在了JNDI树上,
每一个DataSource都有一个name,
客户端通过name找到在JNDI树上绑定的DataSource,
再由DataSource找到一个连接
|- name:表示以后要查找的名称。通过此名称可以找到DataSource,此名称任意更换,但是程序中最终要查找的就是此名称,
|- auth:由容器进行授权及管理,指的用户名和密码是否可以在容器上生效,可以使用Container
|- type:此名称所代表的类型,现在为javax.sql.DataSource(不用变)
|- maxActive:表示一个数据库在此服务器上所能打开的最大连接数
|- maxIdle:表示一个数据库在此服务器上维持的最小连接数
|- maxWait:最大等待时间。10000毫秒
|- username:数据库连接的用户名
|- password:数据库连接的密码
|- driverClassName:数据库连接的驱动程序
|- url:数据库连接的地址
-->
<Resource
name="jdbc/mysql"
auth="Container"
type="javax.sql.DataSource"
maxActive="100"
maxIdle="30"
maxWait="10000"
username="root"
password="whr110112119"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/mydb?useUnicode=true&characterEncoding=utf-8"/>
</Context>
3.在web.xml文件中进行配置(可配置也可以不配置)
如果要配置的话:
1. <resource-ref>
2. <description>my DB Connection</description>
3. <res-ref-name><span style="font-family: Arial, Helvetica, sans-serif;">jdbc/sqlserver</span><span style="font-family: Arial, Helvetica, sans-serif;"></res-ref-name>这个名字要与context.xml中的name一样</span>
4. <res-type>javax.sql.DataSource</res-type>
5. <res-auth>Container</res-auth>
6. </resource-ref>
其中res-ref-name值要和context.xml的name值一致
4.如果使用Spring的情况下
在applicationContext.xml或者自己的Spring的配置文件中导入JNDI的配置信息
//获得content.xml中JNDI配置的数据库的连接池信息。jndi-name必须与JNDI中的name值一样
<jee:jndi-lookup id="dataSource" jndi-name="jdbc/mysql" />
//使用JdbcTemplate操作数据库。
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource" />
</bean>
在java文件中使用IOC得到jdbcTemplate对象。最后使用jdbcTemplate操作数据库
jndi测试方法:
1. public void testJNDI() throws NamingException, SQLException{
2. Context ctx = new InitialContext();
3. DataSource ds = (DataSource) ctx.lookup("java:comp/env/jdbc/mysql ");
4. Connection conn = ds.getConnection();
5. System.out.println(conn.isClosed());
6. }
在jsp中调用加载jndi方式(不可以直接用main方法测试,必须通过启动容器从jsp中调用):
写测试的jsp,例如:jndiTest.jsp
1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
2. <%@page import="com.apply.test.JNDITest"%>
3. <%
4. // 调用JNDITest类的testJNDI方法进行测试
5. JNDITest test = new JNDITest();
6. test.testJNDI();
7. out.println("connection pool connected !!");
8. %>
9. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
10. <html>
11. <head>
12. <title>jndi配置测试</title>
13. </head>
14. <body>
15. </body>
16. </html>
5.如果不使用Spring的话,可以在java文件中直接使用:
//JNDI方式
Context ctx = new InitialContext();
//获取数据源
DataSource ds = (DataSource) ctx.lookup("java:comp/env/jdbc/mysql");
//通过数据源取连接池中的连接
conn = ds.getConnection();
(二)全局的JNDI配置
1.在tomcat的安装目录下的conf下的server.xml文件中的GlobalNamingResources标签下加入resource配置信息(局部JNDI在context.xml文件中的resource配置信息)
2.在Web项目中的META-INF下的context中配置
//global中的名字要与server.xml中的名称一样,而这里的name表示当前要使用名称
<ResourceLink name="jdbc/mysql" global="jdbc/mysql" type="javax.sql.DataSource"/>
3.剩下的和配置局部JNDI一样,及第3,第4,第5配置完直接使用就可以了
总结:
如果要配置局部的话,推荐使用第一种方式,这样不依赖tomcat了
但是还是推荐使用第二种方式好,虽然依赖tomat,但是是全局的,而且可以配置多个,对于以后切换使用方便
在项目的web.xml中添加的资源引用可有可无
JNDI和JDBC的区别和联系及其使用方法的更多相关文章
- JNDI 和JDBC的区别
1.JNDI 和JDBC的区别和联系.两者都是API,是一个标准.并不是什么产品或方法.JDBC 全称:Java Database Connectivity 以一种统一的方式来对各种各样的数据库进行存 ...
- JNDI和JDBC的区别-个人理解
网上关于JNDI和JDBC的定义有很多,但是都很官方不容易理解,下面是我最近查阅资料得出的心得体会.希望对你在理解上有一点点的帮助,说的不对的请指正哦. JDBC: 看到最多的就是 Java Data ...
- JNDI和JDBC的区别
最近也是遇见了JNDI这个概念,查了一下,网上的说法太官方,所以参考下一位老哥的博客总结下 JDBC 看到最多的就是,Java Database Connectivity (JDBC)是一个标准的Ja ...
- 使用JNDI或JDBC连接数据库
一. JNDI 1. tomcat环境 找到X:\xxx\......\apache-tomcat-6.0.39\conf\server.xml,在<Host>节点中配置如下: <H ...
- 简述 Hibernate 和 JDBC 的区别、优缺点
1.hibernate是一个开源的.采用面向对象的思想实现ORM映射框架,它对jdbc进行了一层封装,对于数据库的连接.关闭.数据的持久化(增删改查).事务的管理都进行了封装,使得程序开发的时候可以用 ...
- tomcat中配置servlet.xml的JNDI或JDBC连接数据库【原】
tomcat中配置servlet.xml的JNDI或JDBC连接数据库 一. JNDI 1. tomcat环境 找到X:\xxx\......\apache-tomcat-6.0.39\conf\se ...
- 使用JDBC从数据库中查询数据的方法
* ResultSet 结果集:封装了使用JDBC 进行查询的结果 * 1. 调用Statement 对象的 executeQuery(sql) 方法可以得到结果集 * 2. ResultSet 返回 ...
- 二.OC基础--1,对象的存储细节,2,#pragma mark指令,3,函数和对象方法的区别,4,对象和方法之间的关系 ,5.课堂习题
1,对象的存储细节, 1. 当创建一个对象的时候:Person *p1 = [Person new],做了三件事情: 1,申请堆内存空间: 2,给实例变量初始化: 3,返回所申请空间的首地址; 2. ...
- JDBC使用游标实现分页查询的方法
本文实例讲述了JDBC使用游标实现分页查询的方法.分享给大家供大家参考,具体如下: /** * 一次只从数据库中查询最大maxCount条记录 * @param sql 传入的sql语句 * @par ...
随机推荐
- 【CCPC-Wannafly Winter Camp Day3 (Div1) G】排列(水题)
点此看题面 大致题意:已知 \(p\)为\(n\)的一个排列,定义\(A(p)_i=min_{j=1}^ip_j\),若用\(q_i\)表示\(p\)第\(i\)小的前缀的长度(以值为第一关键字,下标 ...
- (转)Fidder详解之get和post请求
https://www.cnblogs.com/langhuagungun/p/7737204.html 前言 本文会对Fidder这款工具的一些重要功 能,进行详细讲解,带大家进入Fidder的世界 ...
- Linux下进程信息的深入分析[转]
这里我们主要介绍进程的状态,进程的状态可以通过/proc/PID/status来查看,也可以通过/proc/PID/stat来查看. 如果说到工具大家用的最多的ps也可以看到进程的信息.这里我们通过/ ...
- 基于指令的移植方式的几个重要概念的理解(OpenHMPP, OpenACC)-转载
引言: 什么是基于指令的移植方式呢?首先我这里说的移植可以理解为把原先在CPU上跑的程序放到像GPU一样的协处理器上跑的这个过程.在英文里可以叫Porting.移植有两种方式:一种是使用CUDA或者O ...
- 曲率(Curvature)
原文链接 几何体的曲率对于不同的对象有不同的定义.首先来看最简单的平面曲线. 首先把曲线分成无穷小的小段,每一段看作某个圆的一小段圆弧.这个圆叫做“密切圆”(Osculating Circle).由于 ...
- 重定向跳出父Frame
当session过期后可以用过滤器来设置重定向页面 代码如下: public class ActionFilter extends HttpServlet implements Filter {pri ...
- 前端小记4——高性能mobile web开发
1.高性能CSS3动画 与PC端场景需要相比,移动web端需要考虑的因素也相对复杂,重点考虑:流量.功耗与流畅度.在pc端上考虑更多的是流畅度,而mobile web中需要考虑网络流量的使用和耗电情况 ...
- Unexpected token o in JSON at position 1
ajax返回的数据已经是object格式,无需再使用“var newjsonObj = JSON.parse(jsonObj)” 进行转换.
- java Web 常见错误集锦 及解决方法
只能删除pid为整数的商品,32位的pid商品不能删除? 原因onclick="agree('${s.pid}')" 括号中需要加 ' ' 删除多余的工作空间? 使用prefer ...
- iOS圆角view的Swift实现(利用Core Graphics绘制)
iOS圆角view的Swift实现(利用Core Graphics绘制) 因为app的列表用用到了圆形图片的头像,所以去探究并思考了一下这个问题.首先这个问题有两个方向的解决方案: 把图片弄成圆形的. ...