版权声明:本文为博主原创文章,未经博主同意不得转载。 https://blog.csdn.net/zhuojiajin/article/details/32150883

    在了解JDBC之前呢,我们能够先对ODBC做一个回想,以便于更好的理解JDBC。看名字也知道这两个关系不一般,他们实现了相同的功能。为应用程序连接和操作数据库提供支持。所以,我们先从ODBC開始。

ODBC

ODBC(Open Database Connectivity)是开放数据库互连的简称,是一种使用SQL的应用程序接口。它是一系列的规范和对数据库訪问的API。那么API+SQL就能够运行对数据库的操作。它是不依赖于DBMS的,即通过ODBC能够以相同的方式连接大部分数据库。

它包括了应用程序接口、驱动器管理器、数据库驱动器、数据源。

以下我们通过一副图来了解ODBC各个部分之间的关系:

JDBC

    之前说过了JDBC和ODBC实际上的功能是一致的,仅仅只是实现不太一样。首先ODBC是基于C++语言的。那么与Java的面向对象思想不太相符。通信比較困难。

因此,JDBC就出项了,即JDBC是基于JAVA语言的数据库訪问API接口。

然后其它内容就和ODBC基本一致了。仅仅要你了解了ODBC,那么在概念上基本就理解了JDBC。那么你须要做的就是对新面孔出项的接口再了解一遍就好了,而且这些接口的功能和ODBC是一致的,仅仅是说在实现上有细微的区别。以下也看看JDBC的结构图:

    连接方式

    由上面的结构图能够看出来。JDBC提供了多种不同的连接方式。这个做个大概的了解吧,由于这主要是数据库厂商关心的事,我们知道就好了,有些也确实不是非常明确。
     1、JDBC-ODBC连接桥:这样的方式是一位ODBC为基础的。上面说了java应用程序和ODBC之间的通信是有点麻烦的。可是ODBC作为一种数据库訪问的标准应用是非常广的。

因此JDBC通过映射ODBC的功能调用就保证了原来使用ODBC的数据库也能够非常方便的訪问的。

     2、本地API驱动:即把JDBC调用转换为对数据库接口的client二进制代码库的调用。

可是这个接口库依赖于产商。由于这里我们调用的不是数据库厂商提供的JDBC的接口实现。
     3、纯Java本地协议:即把JDBC调用映射为DBMS的网络监听协议的功能调用,监听程序监听到请求后运行相关的数据库操作。监听程序是由厂商提供的。

   经常使用接口简介

  DriverManager

    关于驱动程序怎样注冊的。我们不须要知道。我们须要知道的是,怎样调用方法去载入得到数据库驱动程序就好了。

即Class.forName()方法,调用这种方法须要传递一个包括该驱动程序类名的String对象作为实參。例如以下:   

  1. Class.forName("oracle.jdbc.driver.OracleDriver")

    Connection

    载入了驱动程序后,与数据库建立连接须要调用DriverManager.getConnection()方法,此方法须要数据库URL作为參数,不同的数据库URL的有些区别,但都符合“协议名 + Ip地址+port号+数据库名”的格式。数据库username与password假设有,也得加上。例如以下:    

  1. String url = "jdbc:oracle:thin:@localhost:1521:pdborcl";
  2. String username = "123";
  3. String password = "123";
  4. Connection conn = DriverManager.getConnection(url, username, password);

    StateMent

    运行静态的SQL语句。它还能够组合多个SQL语句成为一个批处理,总体提交给数据库。我们通过Connection对象来创建Statement对象,然后用Statement的execute方法来运行SQL。另外PreparedStatement对象是继承自Statement对象的,这里我们用PreparedStatement为例。须要注意的是批处理仅仅能用Statement对象来运行。 

  1. PreparedStatement pstmt = conn.prepareStatement("select * from t_user where userId=?");
  2. pstmt.setInt(1, id);
  3. ResultSet rs = pstmt.executeQuery();

    ResultSet

    运行一个SQL查询之后的结果集,Result具有指向当前行的指针,能够用来读取结果集中的数据。初始时指针指向第一行前面。该对象的Next()方法能够移动指针。

假设Next()之后的行合法返回True,否则False。因此,循环时Next()方法作为推断根据。

    到这里JDBC的简介就结束了,JDBC在使用中充当了一个沟通者的角色。这让我想起姚明在NBA打球的那个设计模式:适配器模式,这也就成就了Java应用程序跨平台的特性。同一时候,JDBC、ODBC等也是面向接口编程思想的典型体现。

 对了,这里还缺了一个OLE DB。没有提及。下回吧……

数据库訪问技术之JDBC的更多相关文章

  1. 学习实践:使用模式,原则实现一个C++数据库訪问类

    一.概述 在我參与的多个项目中.大家使用libMySQL操作MySQL数据库,并且是源代码级复用,在多个项目中同样或相似的源代码.这种复用方式给开发带来了不便. libMySQL的使用比較麻烦.非常e ...

  2. Java数据库訪问小结

    </pre>1.JDBC訪问方法</p><p></p><p>DBHelper类訪问数据库.Dao类写数据訪问,View类进行应用,初学实例图 ...

  3. c#数据库訪问返回值类型为SqlDataReader时使用using时注意的问题

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u010512579/article/details/24011761 在封装通用 SQLSERVER ...

  4. 使用ADO.NET对SQL Server数据库进行訪问

    在上一篇博客中我们给大家简介了一下VB.NET语言的一些情况,至于理论知识的学习我们能够利用VB的知识体系为基础.再将面向对象程序设计语言的知识进行融合便可进行编程实战. 假设我们须要訪问一个企业关系 ...

  5. php訪问mysql数据库

    PHP訪问Mysql数据库 PHP能够通过mysql接口和mysqli接口訪问mysql数据库. 须要加入mysql和mysqli接口才干訪问mysql数据库. windows下配置amp: a.安装 ...

  6. 訪问远程WAMP 下phpmyadmin

    WAMP环境是一个非常优秀的webservice集成环境,它集成的phpmyadmin也是一款非常优秀的数据库訪问软件.wamp默认安装下,phpmyadmin工具仅仅能本地用,在站点开发中,数据库都 ...

  7. 嵌套SQL语句訪问DB2中SQLCA的调用技巧

    在IBM的关系型数据库产品DB2中,使用SQL Communication Area(SQLCA)将程序中嵌套的SQL语句执行情况返回给程序. 在程序中有针对性地对SQLCA实施调用,可对程序中各类S ...

  8. 假设在本地搭一个server和mysql数据库环境,假设使用java来訪问数据库

    我们能够使用speedamp来搭一个server环境,能够在http://download.csdn.net/detail/baidu_nod/7630265下载 解压后无需安装直接能够使用.点击Sp ...

  9. 动态IP或无公网IP时外网訪问内网ORACLE数据库

    ORACLE数据库是应用最多的一个数据库.一般项目应用.将ORACLE部署在内网,内网调用,及运维都仅仅能是内网完毕. 假设ORACLE主机或所在局域网没有固定公网IP,又想在外网对ORACLE进行訪 ...

随机推荐

  1. Lucene 04 - 学习使用Lucene的Field(字段)

    目录 1 Field的特性 2 常用的Field类型 3 常用的Field种类使用 3.1 准备环境 3.2 需求分析 3.3 修改代码 3.4 重新建立索引 1 Field的特性 Document( ...

  2. JDK源码分析(6)之 LinkedHashMap 相关

    LinkedHashMap实质是HashMap+LinkedList,提供了顺序访问的功能:所以在看这篇博客之前最好先看一下我之前的两篇博客,HashMap 相关 和 LinkedList 相关: 一 ...

  3. [十二]JavaIO之BufferedInputStream BufferedOutputStream

    功能简介 BufferedInputStream 和 BufferedOutputStream一样,他们都是过滤流 装饰器模式下具体的装饰类 用来装饰InputStream以及OutputStream ...

  4. 图解ARP协议(三)ARP防御篇-如何揪出“内鬼”并“优雅的还手”

    一.ARP防御概述 通过之前的文章,我们已经了解了ARP攻击的危害,黑客采用ARP软件进行扫描并发送欺骗应答,同处一个局域网的普通用户就可能遭受断网攻击.流量被限.账号被窃的危险.由于攻击门槛非常低, ...

  5. php 时间戳最大值

    今天遇到一个bug,获取有效期值错误,在定位跟踪后发现有效期有值,如下: $expireDate = ; //2037-08-16 09:30:48 但是在该时间戳的基础上加上1 year后, $ex ...

  6. php将表单中数据传入到数据库

    <html> <head> <meta http-equiv="Content-Type" content="text/html; char ...

  7. centos7 Failed to start firewalld.service: Unit is masked.

    centos7 启动防火墙失败:Failed to start firewalld.service: Unit is masked.   ---- 刚yum安装了iptables 解决: 执行”sys ...

  8. 小tips:JS之for in、Object.keys()和Object.getOwnPropertyNames()的区别

    for..in循环 使用for..in循环时,返回的是所有能够通过对象访问的.可枚举的属性,既包括存在于实例中的属性,也包括存在于原型中的实例.这里需要注意的是使用for-in返回的属性因各个浏览器厂 ...

  9. Dynamics 365-如何利用Audit History还原被删除的数据

    Audit History,常被用来记录record的日常操作信息,包括创建,更新,删除.这是一个非常实用的功能,想想看,如果数据被误修改了,通过Audit History,可以很容易地找到修改前的数 ...

  10. Android为TV端助力(转载)

    作者地址http://www.jianshu.com/u/63915ef020e2 针对Android Tv的自定义RecyclerView 作者 wenju_song 关注 2016.12.09 1 ...