一、JDBC

package com.direct.util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; public class JDBCutil {
/*
* 目前使用的JDBC连接数据库,存在问题:
* 每次连接和释放需要比较多的资源
* 资源浪费比较严重,系统的性能下滑
*
* 连接池的原理:
* 提前设定好,数据库的连接对象,当用户连接数据库时,直接从
* “池子”中取出一个连接即可。
* 当用户使用完毕后,“关闭连接”不是物理关闭,而是把连接放回连接池中
*/ private static final String DRIVER="com.mysql.jdbc.Driver";
private static final String URL="jdbc:mysql://localhost:3306/countryside_buy?userUnicode=true&characterEncoding=utf-8";
private static final String USER="root";
private static final String PWD="123456";
static{
try {
Class.forName(DRIVER);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
//获得链接
public Connection createConn(){
Connection conn = null;
try {
conn = DriverManager.getConnection(URL, USER, PWD);
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
} //关闭连接
public void closeJ(Connection conn,PreparedStatement ps,ResultSet rs) throws SQLException{
if(rs!=null) rs.close();
if(ps!=null) ps.close();
if(conn!=null) conn.close();
}
}

  

二,DBCP

2.1 dbcp.properties

username=root
password=123456
driverClassName=com.mysql.jdbc.Driver
maxActive=2000
maxIdle=520
maxWait=5000
url=jdbc\:mysql\://localhost\:3306/countryside_buy

2.2 DBCPutil

package com.direct.util;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.ResourceBundle; import javax.sql.DataSource; import org.apache.commons.dbcp.BasicDataSource;
/*
* DBCP使用步骤:
* 1,下载需要的jar包,放入web项目的lib下面
* 2,在src下面建立配置文件 .properties
* 3, 建立连接数据库工具,获取配置信息,
* 4,commons-dbcp.jar
* commons-pool-1.5.3.jar
* musql-connector-java-5.1.7.jar
*/ public class DBCPutil {
//数据源
private static DataSource ds= null;
//基本数据源
static BasicDataSource bds = new BasicDataSource();
public static Connection getconn() throws SQLException{
if (ds==null) {
ResourceBundle rs = ResourceBundle.getBundle("dbcp");
String username = rs.getString("username");
String password = rs.getString("password");
String driverClassName = rs.getString("driverClassName");
String maxActive = rs.getString("maxActive");
String maxIdle = rs.getString("maxIdle");
String maxWait = rs.getString("maxWait");
String url = rs.getString("url"); bds.setMaxActive(Integer.parseInt(maxActive));
bds.setMaxIdle(Integer.parseInt(maxIdle));
bds.setMaxWait(Integer.parseInt(maxWait));
bds.setUrl(url);
bds.setUsername(username);
bds.setPassword(password);
bds.setDriverClassName(driverClassName); ds = bds;
return ds.getConnection(); }
return ds.getConnection();
}
//测试
public static void main(String[] args) {
try {
System.out.println(getconn());
} catch (SQLException e) {
e.printStackTrace();
}
} }

三,JNDI

1,所需放在tomcat安装路径的lib目录下  commons.pool-1.5.3.jar  和  mysql-connector-java-5.1.7-bin.jar

2,tomcat中找到config文件夹下的context.xml

在标签<Context>中添加

	<Resource
name="jndiDemo"
auth="Container"
type="javax.sql.DataSource"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/countryside_buy"
username="root"
password="123456"
maxActive="100"
maxIdle="30"
maxWait="3000"
/>

3,项目的web.xml中添加映射

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <!-- 配置JNDI -->
<resource-ref>
<res-ref-name>jndiDemo</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref> <servlet>
<description>This is the description of my J2EE component</description>
<display-name>This is the display name of my J2EE component</display-name>
<servlet-name>JndiServlet</servlet-name>
<servlet-class>com.direct.servlet.JndiServlet</servlet-class>
</servlet> <servlet-mapping>
<servlet-name>JndiServlet</servlet-name>
<url-pattern>/JndiServlet</url-pattern>
</servlet-mapping> <welcome-file-list>
<welcome-file>register.jsp</welcome-file>
</welcome-file-list>
</web-app>

4,jndi类

package com.direct.util;

import java.sql.Connection;
import java.sql.SQLException; import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource; public class JNDIutil {
/*
* JNDI是tomcat提供的一种标准的连接池
* 1,将驱动放入项目中tomcat的lib目录下
* 2,修改配置文件(tomcat中找到config文件夹下的context.xml)
* 3,在web.xml下配置
*/
public static Connection conn(){
Connection connection = null;
try {
//获得对数据源的引用
Context context = new InitialContext();
DataSource ds = (DataSource)context.lookup("java:comp/env/jndiDemo");
//获得数据库连接对象
connection = ds.getConnection();
} catch (NamingException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return connection; }
}

 5,servlet 测试jndi

package com.direct.servlet;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import com.direct.util.JNDIutil; public class JndiServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { response.setContentType("text/html");
System.out.println(new JNDIutil().conn());
//jdbc:mysql://localhost:3306/countryside_buy, UserName=root@localhost, MySQL-AB JDBC Driver } }

  最后开启服务器,访问 jndiServlet 后台即可得到连接,并输出连接地址

连接数据库 JDBC、DBCP、JNDI的更多相关文章

  1. 理解JDBC和JNDI

    下面的英文是我找过来的,因为是英文所以不敢翻译出来误导别人,但是它描述的确实恰到好处,比所谓网上的JNDI和JDBC云云的解释要精辟很多,如果遇到不认识的单词,用有道吧~~:) The Java Na ...

  2. JDBC、JNDI和DBCP的区别

    JDBC:Java DataBase Connectivity,java连接数据库和执行SQL语句的API. 数据源:Data Source.就是将IP.数据库.用户名.密码封装起来对外只提供一个JN ...

  3. tomcat+dbcp+jndi 配置

    1)添加jar包 tomcat6中 TOMCAT_HOME/lib 下是公用jar包 dbcp需要3个jar包:Jakarta-Commons DBCP,Jakarta-Commons Collect ...

  4. java jdbc dbcp连接SQL Server

    使用到的jar: commons-collections-3.1.jar commons-dbcp-1.4.jar commons-pool-1.5.6.jar sqljdbc4.jar dbcp配置 ...

  5. java连接数据库——JDBC连接数据库

    DBUtil.java   // 数据库操作文件 package com.bjpowernode.jdbc.util; import java.io.File; import java.io.File ...

  6. JDBC与JNDI的区别

    程序员开发时,知道要开发访问MySQL数据库的应用,于是将一个对 MySQL JDBC 驱动程序类的引用进行了编码,并通过使用适当的 JDBC URL 连接到数据库. 就像以下代码这样: Connec ...

  7. java连接数据库(jdbc)调用配置文件

    各种语言都有自己所支持的配置文件,后缀名“.properties”结尾的就是其中之一. 在java连接数据库时,采取读取配置文件的方式,来获取数据库连接. 新建jdbc.properties文件,内容 ...

  8. JSP 连接数据库JDBC有一定的了解

    JSP 连接数据库 本章节假设您已经对JDBC有一定的了解.在开始学习JSP数据库访问前,请确保JDBC环境已经正确配置. 首先,让我们按照下面的步骤来创建一个简单的表并插入几条简单的记录: 创建表 ...

  9. c3p0;jdbc;dbcp;mybatis;ubutils;

    [说明]今天还是完成了一定东西的,上午是jdbc的测试,下午是 数据库连接池 和 dbutils 的测试,晚上是mybatis的测试,都是找了一些网上的例子运行了一下,解决出现的问题. 一:今日完成 ...

随机推荐

  1. php程序开销比较

    内存最快 文件次之 数据库最慢

  2. Spring配置项<context:annotation-config>的解释说明

    今天在闲逛CSDN论坛时,看到一位博主写的一篇关于<Spring中IOC的Annotation的实现>的文章, 于是点击进去看了下, 发现在说明中对Spring配置文件中的有些配置节点模凌 ...

  3. 微信小程序组件化实践

    Do Not Repeat Yourself 如何提高代码质量,方法有许多:抽象.模块.组件化,我认为它们的中心点都是--Do Not Repeat Yourself. 小程序组件化 我们先看看小程序 ...

  4. Window Navigator对象

    Window Navigator对象 txt = "<p>浏览器代号: " + navigator.appCodeName + "</p>&quo ...

  5. deepin安装Mariadb后,登录时出现ERROR 1045 (28000): Access denied for user 'root'@'localhost'

    安装Mariadb的时候设置了root密码,但是登录的时候出现了这样的提示 这里记录下我的处理方法.我是用的如果重置root密码的套路. 首先,在/etc/mysql/mariadb.conf.d/5 ...

  6. 【DB2】关闭表的日志功能

    2018.11.19 客户遇到一个问题,在import数据的时候,产生了大量的日志,客户的数据库是HADR模式,通过评估,这几张表是可以允许在备库上不查询的,表中的数据时临时的. 方案一:修改脚本,将 ...

  7. Java之集合(二十五)ConcurrentHashMap

    转载请注明源出处:http://www.cnblogs.com/lighten/p/7520808.html 1.前言 本章介绍使用的最频繁的并发集合类之一ConcurrentHashMap,之前介绍 ...

  8. Spring Security构建Rest服务-0701-个性化用户认证流程

    上一篇说了用户认证的基本流程,但是上一篇当访问一个受保护的服务后,如果未认证会调到默认的登录页面,这样是不行的,而且认证成功后,就直接访问了那个服务,如果想要做认证成功后做一些操作,还需要自定义. 个 ...

  9. java数据结构之递归算法

    概述程序调用自身的编程技巧称为递归( recursion).递归做为一种算法在程序设计语言中广泛应用.递归有直接递归和间接递归•直接递归:函数在执行过程中调用本身.•间接递归:函数在执行过程中调用其它 ...

  10. spring boot整合Swagger2

    Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化RESTful风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法,参数和模型紧密集成到服务器 ...