文档章节

JDBC学习笔记

tao975
 tao975
发布于 2015/04/22 10:20
字数 1339
阅读 14
收藏 0

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








© 著作权归作者所有

共有 人打赏支持
下一篇: JSP学习笔记
tao975
粉丝 1
博文 10
码字总数 34471
作品 0
广州
私信 提问
111 多线程JUC包下代码分析

Java多线程系列目录(共43篇) AtomicLongFieldUpdater:通过反射+CAS实现对传入对象的指定long字段实现类似AtomicLong的操作 http://www.cnblogs.com/skywang12345/p/javathreadscategory.ht...

素雷
2017/10/31
0
0
全新互联网Java后端开发技术思维导图

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/t4i2b10X4c22nF6A/article/details/82714797 图文里的技术如何学习,有没有免费资料? 对Java的技术,架构技术...

JAVA高级架构v
09/15
0
0
一份关于 Java、Kotlin 与 Android 的学习笔记

JavaKotlinAndroidLearn 这是一份关于 Java 、Kotlin 、Android 的学习笔记,既包含对基础知识点的介绍,也包含对一些重要知识点的源码解析,笔记的大纲如下所示: Java 重拾Java(0)-基础知...

叶应是叶
08/08
0
0
阿里P8架构师总结的互联网Java架构系统化学习路线

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/t4i2b10X4c22nF6A/article/details/83181980 网络应用,最常见的研发语言是Java的和PHP。 后端服务,最常见的...

JAVA高级架构v
10/19
0
0
用思维导图来学java虚拟机,轻松易懂!

说明 本篇文章是对周志明的《深入理解Java虚拟机》的读书笔记,思维导图使用Mindjet MindManager。曾经看到过这样一句话: 关于教育,有一个经典的定义是:把在学校里学到的东西全部忘掉,最...

小刀爱编程
10/12
0
0

没有更多内容

加载失败,请刷新页面

加载更多

大数据教程(6.1)hadoop生态圈介绍及就业前景

1. HADOOP背景介绍 1.1、什么是HADOOP 1.HADOOP是apache旗下的一套开源软件平台 2.HADOOP提供的功能:利用服务器集群,根据用户的自定义业务逻辑,对海量数据进行分布式处理 3.HADOOP的核心组...

em_aaron
8分钟前
0
0
hadoop垃圾回收站

在生产生,hdfs回收站必须是开启的,一般设置为7天。 fs.trash.interval 为垃圾回收站保留时间,如果为0则禁用回收站功能。 fs.trash.checkpoint.interval 回收站检查点时间,一般设置为小于...

hnairdb
昨天
0
0
腾讯与Github的魔幻会面背后的故事…

10月22日,腾讯开源管理办公室有幸邀请到Github新晋CEO Nat Friedman,前来鹅厂参观交流。目前腾讯已经有近70个项目在Github上开源,共获得17w stars,世界排名11位。Github是腾讯开源的主阵...

腾讯开源
昨天
1
0
单例模式

单例模式(Singleton pattern)属于创建型设计模式。 保证一个类仅有一个实例,并提供一个访问它的全局访问点。 通常我们可以让一个全局变量使得一个对象被访问,但它不能防止你实例化多个对...

NinjaFrog
昨天
1
0
TypeScript基础入门之装饰器(三)

转载 TypeScript基础入门之装饰器(三) 继续上篇文章[TypeScript基础入门之装饰器(二)] 访问器装饰器 Accessor Decorator在访问器声明之前声明。 访问器装饰器应用于访问器的属性描述符,可用...

durban
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部