一、JDBC_通过Driver接口获取数据库连接

1、 Driver是一个接口:数据库厂商必须提供实现的接口,可以从其中 获取数据库连接。

2、JDBC URL由三部分组成,各部分用冒号隔开,格式:jdbc:<子协议>:<子名称>

  协议:JDBC URL中的协议总是jdbc  jdbc

  子协议:子协议用于标识一个数据库驱动程序   mysql

  子 名称:一种标识数据库的方法,子名称可以依不同的子协议而变化,用自名称的目的是为了定位数据库,提供足够的信息。   localhost:3306/test

3、Properties类

     JAVA的包中,有提供专门的操作属性文件的类,java.uitl.Properties类,该类是一个集合类,所以,Properties会将属性以集合的方式读写;

  该类的详细介绍参考:   http://blog.csdn.net/qinpeng100423/article/details/9125857

4、代码实现

@Test
 public void test() throws SQLException {
    Driver driver=new Driver();
    String url="jdbc:mysql://192.168.56.1:3306/test";
    Properties info=new Properties();
    info.put("user", "root");
    info.put("password", "kk");
    Connection connection=driver.connect(url, info);
    System.out.println(connection);
 }

5、编写一个通用的方法,在不修改原程序的情况下,可以获取任何数据库的连接?

  ---将数据库驱动Driver实现类的全类名、url、user、password放入一个配置文件中,通过修改配置文件的方式实现和具体的数据库解耦。

实现如下:

1>准备连接数据库的4个字符串

2>获取jdbc.properties对应的输入流

3>创建Properties对象

4>加载对应的输入流

5>具体决定以上4个字符串

6>加载数据库驱动程序

7>获取数据库连接

public Connection getConnection() throws Exception{
  
    String driverClass=null;
    String jdbcUrl=null;
    String user=null;
    String password=null;
  
    //读取类路径下的jdbc.properties文件
    InputStream in=getClass().getClassLoader().getResourceAsStream("jdbc.properties");
    Properties properties=new Properties();

   //加载输入流
    properties.load(in);
  
    driverClass=properties.getProperty("driver");
    jdbcUrl=properties.getProperty("jdbcUrl");
    user=properties.getProperty("user");
    password=properties.getProperty("password");
    //通过反射创建Driver对象
    Driver driver=(Driver)Class.forName(driverClass).newInstance();
  
    Properties info=new Properties();
    info.put("user", user);
    info.put("password", password);
    Connection connection=driver.connect(jdbcUrl,info);
    return connection;
 }

jdbc.properties配置文件:

  driver=com.mysql.jdbc.Driver
  jdbcUrl=jdbc:mysql://192.168.56.1:3306/test
  user=root
  password=kk

二、通过DriverManager的getConnection()方法获取数据库连接

1、DriverManager是驱动的管理类:

    1>可以通过重载的getConnection()方法获取数据库连接,较为方便

    2>可以同时管理多个驱动程序:若注册了多个数据库连接,则调用getConnection()方法时传入的参数不同,即返回不同的数据库连接。

2、代码实现

1>准备连接数据库的4个字符串

2>获取jdbc.properties对应的输入流

3>创建Properties对象

4>加载对应的输入流

5>具体决定以上4个字符串

6>加载数据库驱动程序(对应的Driver实现类中有注册驱动的静态代码块)

7>获取数据库连接

@Test
 public void testDriverManager() throws Exception{
    //1、准备数据库连接的4个字符串
    String driverClass=null;   //驱动的全类名
    String jdbcUrl=null;      //JDBC URL
    String user=null;
    String password=null;
  
    //读取类路径下的jdbc.properties文件
    InputStream in=getClass().getClassLoader().getResourceAsStream("jdbc.properties");
    Properties properties=new Properties();
    properties.load(in);
    driverClass=properties.getProperty("driver");
    jdbcUrl=properties.getProperty("jdbcUrl");
    user=properties.getProperty("user");
    password=properties.getProperty("password");
    //加载数据库驱动程序
    Class.forName(driverClass);
    //通过DriverManager的getConnection()方法获取数据库连接
    Connection connection=DriverManager.getConnection(jdbcUrl,user,password);
    System.out.println(connection);
 }
 @Test
 public void testDriverManager1() throws Exception{
    //1、准备数据库连接的4个字符串
    String driverClass="com.mysql.jdbc.Driver";   //驱动的全类名
    String jdbcUrl="jdbc:mysql:///test";      //JDBC URL
    String user="root";
    String password="kk";
  
    //加载数据库驱动程序
    Class.forName(driverClass);
    //通过DriverManager的getConnection()方法获取数据库连接
    Connection connection=DriverManager.getConnection(jdbcUrl,user,password);
    System.out.println("向日葵:"+connection);
 }

  

三、数据库连接释放工具类

JDBCTools.java

import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

public class JDBCTools {

  public static Connection getConnection() throws Exception {

     String driverClass = null;
      String jdbcUrl = null;
      String user = null;
      String password = null;

    // 读取类路径下的jdbc.properties文件
      InputStream in = JDBCTools.class.getClassLoader().getResourceAsStream("jdbc.properties");
      Properties properties = new Properties();
      properties.load(in);

     driverClass = properties.getProperty("driver");
      jdbcUrl = properties.getProperty("jdbcUrl");
      user = properties.getProperty("user");
      password = properties.getProperty("password");
      // 加载数据库驱动程序
      Class.forName(driverClass);
      // 通过DriverManager的getConnection()方法获取数据库连接
      Connection connection = DriverManager.getConnection(jdbcUrl, user, password);
      return connection;

   }
 
   public static void release(Statement st,Connection conn){
  
      if (st!=null) {
         try {
            st.close();
         } catch (SQLException e) {
            e.printStackTrace();
         }
      }
  
      if (conn!=null) {
         try {
            conn.close();
         } catch (SQLException e) {
            e.printStackTrace();
         }
      }
    }
}

  

<一>获取数据库连接的更多相关文章

  1. JAVA jdbc获取数据库连接

    JDBC获取数据库连接的帮助类 import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManage ...

  2. 使用DriverManager获取数据库连接的一个小改进

    由于使用DriverManager获取数据库连接时,由于DriverManager实现类中有一段静态代码块,可以直接注册驱动,且可以同时管理多个驱动程序 所以当换数据库连接时需要指定不同的数据库,那么 ...

  3. 使用DriverManager获取数据库连接

    DriverManager 是驱动的管理类 * 1).可以通过重载的getConnection() 方法获取数据库连接,较为方便 * 2).可以同时管理多个驱动程序,若注册了多个数据库连接,则调用ge ...

  4. 通过Driver获取数据库连接

    先看一下文件,在当前包下有一个properties配置文件,在根目录下有一个lib文件夹,里面放的是mySql的驱动jar包 Driver :是一个接口,数据库厂商必须提供实现的接口,能从其中获取数据 ...

  5. JDBC_获取数据库连接

    <span style="font-size:24px;">package src.com.jdbc.java; import java.io.IOException; ...

  6. 获取数据库连接对象Connection

    2018-11-04  19:50:52 开始写 public Connection getConn() {//返回类型为Connection try { Class.forName("co ...

  7. JDBC编程:获取数据库连接

    JDBC(Java Database Connectivity),即Java数据库连接.通过JDBC编程,可以使Java应用程序和数据库进行交互. JDBC驱动的方式有很多种,我们常用的驱动方式为:本 ...

  8. JDBC 学习笔记(四)—— JDBC 加载数据库驱动,获取数据库连接

    1. 加载数据库驱动 通常来说,JDBC 使用 Class 类的 forName() 静态方法来加载驱动,需要输入数据库驱动代表的字符串. 例如: 加载 MySQL 驱动: Class.forName ...

  9. 获取数据库连接的方式 & Statement操作数据库的弊端

    1.获取数据库连接的方式 TestConnection package com.aff.connection; import java.io.InputStream; import java.sql. ...

随机推荐

  1. 如何让ConfigurationManager打开任意的配置文件

    VisualStudio的配置文件很好很强大,用来保存数据库连接字符串或键值对都非常方便,只需要通过ConfigurationManager的ConnectionStrings或AppSettings ...

  2. pyquery的问题

    在使用pyquery时发现一些问题, 1.爬取的html中如果有较多的错误时,不能很好的补全. 2.如果要获取某个class中的内容时,如果内容太多不能取完整!只能取一部分. 这个在现在的最新版本中还 ...

  3. vtkAnimationCue、vtkCommand和vtkAVIWriter

    1. 用vtkAnimationCue自定义一个vtkCustomAnimationCue类,用来实现球体逐渐张开的过程: 2.用vtkCommand自定义衍生一个vtkCustomAnimation ...

  4. openjdk 完全编译指南

    从openjdk.java.net下载openjdk的软件包,你就获得了所有相关的源码. 强烈建议首先仔细看懂 README-builds.html 指南. 在执行 make all 之前,首先要 执 ...

  5. vijos1404 遭遇战

    描述 今天,他们在打一张叫DUSTII的地图,万恶的恐怖分子要炸掉藏在A区的SQC论坛服务器!我们SQC的人誓死不屈,即将于恐怖分子展开激战,准备让一个人守着A区,这样恐怖分子就不能炸掉服务器了.(一 ...

  6. 基本 sql语句

    1.打开数据库 int sqlite3_open( const char *filename,   // 数据库的文件路径 sqlite3 **ppDb          // 数据库实例 ); 2. ...

  7. 【poj2096】Collecting Bugs

    题目描述 Ivan is fond of collecting. Unlike other people who collect post stamps, coins or other materia ...

  8. 浅谈JS之AJAX

    0x00:什么是Ajax? Ajax是Asynchronous Javascript And Xml 的缩写(异步javascript及xml),Ajax是使用javascript在浏览器后台操作HT ...

  9. css3弹性盒模型

    一.简介 css3引入了新的盒模型——弹性盒模型,该模型决定一个盒子在其他盒子中的分布方式以及如何处理可用的空间.使用该模型,可以很轻松的创建自适应浏览器窗口的流动布局或自适应字体大小的弹性布局. 目 ...

  10. c/c++字符串定义及使用的对比

    c/c++中使用字符串的频率还是比较高的,下面就字符串的不同定义及其使用方法做一些对比 字符串一般有以下三种定义方法: 1.char *p="hello"; 2.char str[ ...