文档章节

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








© 著作权归作者所有

共有 人打赏支持
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、Kotlin 与 Android 的学习笔记

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

叶应是叶
08/08
0
0
BAT等大厂Android面试书单和知识点清单

java是Android开发的基础,在BAT的初面中,会涉及到比较多的java基础知识,所以比较重要,下面我介绍的书籍内容是由浅到深。 1.Thinking in java:这本书被称为Java的三大圣经之一,虽然书比...

android自学
07/25
0
0
2018年暑假第一周周总结报告

一眨眼,暑假第一周过去了。这一周大部分时间都是在学校度过的。在7月14日之前,我在学校宿舍待着,便开始刷我的网络课程。虽然这些课看上去不是太重要,但从中也学到了不少知识。 周一,我对...

寂天风
07/15
0
0
2018-3-29 Linux学习笔记

16.1 Tomcat介绍 Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。 java程序写的网站用tomcat+jd...

XiaoluHuang
06/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

(三)Nginx配置·续

概述 前文写了关于Nginx环境配置,但是还没有完,接下来将会继续讲三个相关的配置 主要是以下三个 1.Nginx访问日志 2.Nginx日志切割 3.静态文件不记录日志和过期时间 Nginx访问日志 1.先看看...

杉下
今天
1
0
jquery创建类似于java的map

var map = {}; // Map map = new HashMap(); map[key] = value; // map.put(key, value); var value = map[key]; // Object value = map.get(key); var has = key in map; // boolean has = ......

SuperDabai
今天
0
0
java大数据转换16进制转10进制

public static void main(String[] args) {String hex = "0xdbf3accc683297cf0000";BigInteger amount = new BigInteger(hex.substring(2), 16);System.out.println(amount);......

任梁荣
昨天
2
0
OSChina 周六乱弹 —— 目测我们程序员丁克的几率不大

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @真Skr小机灵鬼儿:8.13分享Jocelyn Pook/Russian Red的单曲《Loving Strangers》 《Loving Strangers》- Jocelyn Pook/Russian Red 手机党少...

小小编辑
昨天
13
3
TypeScript基础入门 - 函数 - 剩余参数

转载 TypeScript基础入门 - 函数 - 剩余参数 项目实践仓库 https://github.com/durban89/typescript_demo.gittag: 1.2.1 为了保证后面的学习演示需要安装下ts-node,这样后面的每个操作都能...

durban
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部