JDBC学习笔记

JDBC学习笔记_第1张图片

1. JDBC是什么?

    JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序
    简单地说,JDBC 可做三件事:与数据库建立连接、发送 SQL 语句并处理结果。

2. 为什么使用JDBC?

    1)通过使用JDBC,可以使用标准的SQL语句访问任何数据库。
    2)高级语言程序员不需要了解底层数据库驱动开发,降低程序员学习量。

3. JDBC使用

    1)JDBC操作数据库一般步骤:
            1> 注册驱动(Driver)
            2> 建立连接(Connection)
            3> 创建执行SQL的语句(Statement)
            4> 执行语句
            5> 处理执行结果(ResultSet)
            6> 释放资源(close)

    2)注册JDBC驱动
        有三种方式:
        1> Class.forName(“com.mysql.jdbc.Driver”);
             推荐这种方式,不会对具体的驱动类产生依赖。
        2> DriverManager.registerDriver(com.mysql.jdbc.Driver);
             会造成DriverManager(驱动管理器)中产生两个一样的驱动,并会对具体的驱动类产生依赖。
        3> System.setProperty(“jdbc.drivers”, “driver1:driver2”);
             虽然不会对具体的驱动类产生依赖;但注册不太方便,所以很少使用。

    3)建立连接
        Connection conn = DriverManager.getConnection(url, user, password);

        url格式:JDBC:子协议:子名称//主机名:端口/数据库名?属性名=属性值&…
        Connection conn = DriverManager.getConnection("jdbc:oracle:thin: @localhost :orcl","scott","tiger");
        默认情况下一个数据库的连接是自动提交模式的(auto-commit)

    4)创建执行SQL的语句(Statement、PreparedStatement、CallableStatement
        CallableStatement:调用存储过程({? = call 过程名[(?, ?, ...)]} )
        Statement和PreparedStatement的区别:
        1>  Statement是一个SQL执行器,可以用来执行一个静态的SQL语句。 PreparedStatement执行动态的SQL语句。
        2> 只执行一次的SQL语句选择Statement是最好的。PreparedStatement的第一次执行消耗是很高的,它的性能体现在后面的重复执行。
        3> Update大量的数据时, 使用PreparedStatement的批处理。PreparedStatement的AddBatch()方法一次性发送多个查询给数据库,减少网络传输

    5)处理执行结果(ResultSet)
        1> ResultSet表示一个查询结果集。
        2> ResultSet中行的第一列索引为1,而非0。
        3> JDBC1.0中,我们只能在ResultSet中向前移动;在JDBC2.0中,我们可以在ResultSet中向下(next)或向上(previous)移动,同样也可以移到特定的行(relative,absolute)
        4> 尽量不要使用getObject()方法,因为JDBC驱动必须对要取得的值的类型作额外的处理以映射为特定的对象,降低了性能。

    6)释放资源
        1> 释放资源的顺序是ResultSet, Statement,Connection;
        2> Connection的使用原则是尽量晚创建,尽量早的释放。

4. 数据库连接池

    1)概念
    数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去。我们可以通过设定连接池最大连接数来防止系统无尽的与数据库连接。
    JDBC的API中没有提供连接池的方法。

    2)连接池的分配与释放
    对于连接的管理可使用空闲池。即把已经创建但尚未分配出去的连接按创建时间存放到一个空闲池中。每当用户请求一个连接时,系统首先检查空闲池内有没有空闲连接。如果有就把建立时间最长(通过容器的顺序存放实现)的那个连接分配给他(实际是先做连接是否有效的判断,如果可用就分配给用户,如不可用就把这个连接从空闲池删掉,重新检测空闲池是否还有连接);如果没有则检查当前所开连接池是否达到连接池所允许的最大连接数(maxConn,如果没有达到,就新建一个连接,如果已经达到,就等待一定的时间(timeout)。如果在等待的时间内有连接被释放出来就可以把这个连接分配给等待的用户,如果等待时间超过预定时间timeout,则返回空值(null)。
    系统可采取设置最小连接数(minConn)和最大连接数(maxConn)来控制连接池中的连接。最小连接数是系统启动时连接池所创建的连接数。如果创建过多,则系统启动就慢,但创建后系统的响应速度会很快;如果创建过少,则系统启动的很快,响应起来却慢。

    3)连接池的实现
        c3p0、dbcp、proxool








你可能感兴趣的:(jdbc,学习,笔记)