文档章节

jdbc详解:1、创建数据库connection连接

白痴糊涂人
 白痴糊涂人
发布于 2017/07/12 17:30
字数 618
阅读 41
收藏 1

新手上路,请多多包涵,文章的不足欢迎吐槽。本文章以mysql为例

相信很多人都会使用jdbc创建数据连接。

    static String driverName = "com.mysql.jdbc.Driver";
    static String url = "jdbc:mysql://127.0.0.1:3306/mysql";
    static String username = "root";
    static String password = "";


    @Test
    public void getConnection1() {

        try {

            // 1、加载驱动
            Class.forName(driverName);

            // 2、获取connection
            Connection conn = DriverManager.getConnection(url,username,password);

            System.out.println(conn);


        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }

    }

代码可以说是非常简单,但是仔细想一下,发现会有2两疑问:

  1. Class.forName(driverName)这样加载去驱动,又没有创建进行赋值给某个变量,DriverManager是如何使用该驱动来创建连接的?

  2. 如果换成别的数据库,只需要把Mysql的驱动换成别的数据库驱动就可以了,其它的代码不用改,这是怎么做到的?

下面进行解答👇

疑问1:

Class.forName(className)这个方法是会执行className这个类的静态代码块的。在我们执行Class.forName("com.mysql.jdbc.Driver")的时候,com.mysql.jdbc.Driver这个类的静态代码块会被执行,然后向DriverManager注册驱动

下面是com.mysql.jdbc.Driver的源码


public class Driver extends NonRegisteringDriver implements java.sql.Driver {
    //
    // Register ourselves with the DriverManager
    //
    static {
        try {
            java.sql.DriverManager.registerDriver(new Driver());
        } catch (SQLException E) {
            throw new RuntimeException("Can't register driver!");
        }
    }

    其它省略
}

疑问2:

这个很简单,定义驱动的接口就可以了,然后交由DriverManager驱动管理器进行管理。jdbc只是定义了java数据库连接的标准,具体的实现是各个数据库厂商实现的。

java.sql.Driver源码


public interface Driver {

    // 要把 username、password等信息put到Properties里面
    Connection connect(String url, java.util.Properties info)
        throws SQLException;

    boolean acceptsURL(String url) throws SQLException;

    DriverPropertyInfo[] getPropertyInfo(String url, java.util.Properties info)
                         throws SQLException;

    int getMajorVersion();

    int getMinorVersion();

    boolean jdbcCompliant();

    //------------------------- JDBC 4.1 -----------------------------------
    public Logger getParentLogger() throws SQLFeatureNotSupportedException;
}

在调用DriverManager.getConnection()的时候,DriverManager其实是使用厂商提供的驱动包内java.sql.Driver的实现类来获取connection的,如果mysql就是使用com.mysql.jdbc.Driver内connect()方法进行连接数据库获取connection。

如果我们不是用DriverManager,那应该怎样获取connection呢??

很简单直接调用java.sql.Driver实现类的connect()方法就可以了。


 @Test
    public void getConnnection2() {

        try {

            // 通过反射创建驱动对象
            Driver driver = (Driver) Class.forName(driverName).newInstance();

            // 你也可以这样写,但是这样耦合太大了
//            com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver();

            // 包装连接信息
            Properties info = new Properties();
            info.put("user", username);
            info.put("password", password);

            // 获取连接
            Connection conn = driver.connect(url, info);

            System.out.println(conn);


        } catch (Exception e) {
            e.printStackTrace();
        }


    }

© 著作权归作者所有

白痴糊涂人
粉丝 5
博文 8
码字总数 6038
作品 0
广州
私信 提问
如何在Oracle中使用Java存储过程 (详解)

其实,这篇短文,我早就应该写了。因为,java存储过程今后在各大数据库厂商中越来越流行,功能也越来越强大。这里以Oracle为例,介绍一下java存储过程的具体用法。 任何转载,请尊重版权。(...

晨曦之光
2012/04/12
133
0
在tomcat中配置JNDI数据源 .

在tomcat5.0中配置数据源(全局数据源、局部数据源),通过连接池机制连接数据库 1. odbc-jdbc桥连 2. 通过加载本地驱动连接 3. 在web应用服务器中设置数据源,通过池接技术连接数据库(加载本...

漠、
2012/05/24
260
0
连接池详解,c3p0与dbcp的区别!

连接池: 连接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。这项技术能明显提高对数据库操作的性能。 连接池的好处: (1)对于大多数应用程序,当它们正...

IT_laobai
2018/06/20
0
0
JDBC连接MySQL数据库及示例

DBC是Sun公司制定的一个可以用Java语言连接数据库的技术。 一、JDBC基础知识 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提...

aminqiao
2014/06/10
211
1
JDBC操作MySQL(crud)

类库链接(mysql-connector-java-5.1.37-bin.jar):http://files.cnblogs.com/files/xujingyang/mysql-connector-java-5.1.37-bin.zip 1.1 JDBC概述 JDBC(Java Data Base Connectivity,java数......

sandshell
2018/08/04
0
0

没有更多内容

加载失败,请刷新页面

加载更多

如何设计抗住100亿次请求的抢红包系统?(附GitHub代码)

1. 前言 前几天,偶然看到了 《扛住100亿次请求——如何做一个“有把握”的春晚红包系统”》一文,看完以后,感慨良多,收益很多。 正所谓他山之石,可以攻玉,虽然此文发表于2015年,我看到...

Java程序员之家
28分钟前
2
0
动图+源码,演示Java中常用数据结构执行过程及原理

最近在整理数据结构方面的知识, 系统化看了下Java中常用数据结构, 突发奇想用动画来绘制数据流转过程. 主要基于jdk8, 可能会有些特性与jdk7之前不相同, 例如LinkedList LinkedHashMap中的双向...

Java技术剑
54分钟前
2
0
怎样在ps中制作对话气泡?一招教你轻松解决

PS是在工作中经常使用的平面设计软件,利用ps可以实现很多操作。换天,换发色,添加亮灯等操作都是比较常见的,今天将为大家分享怎样在ps中制作对话气泡的方法,希望能给大家带来帮助。 绘制...

干货趣分享
今天
2
0
EDI 电子数据交换全解指南

EDI(Electronic Data Interchange,电子数据交换)技术使得企业与企业(B2B)实现通信自动化,帮助交易伙伴和组织更快更好地完成更多工作,并消除了人工操作带来的错误。从零售商到制造商、物...

EDI知行软件
今天
3
0
CentOS7的LVM动态扩容

# 问题 CentOS7上面的磁盘空间有点紧张,需要扩容。 解决 查询当前磁盘状态 [root@xxx ~]# lsblkNAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTfd0 2:0 1 4K ...

亚林瓜子
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部