1. 引言

JDBC API是一种Java API,可以访问任何类型的表格数据,特别是存储在关系数据库中的数据。

JDBC可以帮助我们编写下列三种编程活动的java应用程序:

  • 1.连接到数据源,如数据库;
  • 2.发送查询和更新语句到数据库;
  • 3.检索并处理从数据库收到的结果以满足我们的查询要求。

以下简单的代码片段给出了以下三个步骤的简单示例:

/**
* A demo of JDBC
* @param username : 数据源的登录名
* @param password : 数据源的密码
*/
public void connectToAndQueryDatabase(String username, String password) {Connection con = DriverManager.getConnection("jdbc:myDriver:myDatabase",username,password);Statement stmt = con.createStatement();ResultSet rs = stmt.executeQuery("SELECT a, b, c FROM Table1");while (rs.next()) {int x = rs.getInt("a");String s = rs.getString("b");float f = rs.getFloat("c");}
}

这个很短的代码片段十分简单,实例化一个DriverManager对象,以连接到数据库驱动程序并登录到数据库,该语句将sql语句查询的对象实例化到数据库中,实例化一个ResultSet检索查询结果的对象,并执行一个简单的while循环,检索并显示这些结果。

2. JDBC产品组件

JDBC包括四个组件:

    1. JDBC-API - JDBC™API提供对Java™编程语言的关系数据的编程访问。使用JDBC API,应用程序可以执行SQL语句,检索结果,并将更改发送到底层数据源。此外,JDBC API还可以在分布式异构环境中与多个数据源进行交互。JDBC API是Java平台的一部分,它包括Java™标准版(Java™SE)和Java™企业版(Java™EE)。在JDBC 4.0 API分为两个包:java.sql和javax.sql,在Java SE和Java EE平台均包含这两个包。
    1. JDBC驱动程序管理器 - JDBC DriverManager类定义了一个对象,这个对象可以将java应用程序连接到jdbc驱动程序。从传统上来看,DriverManager是整个JDBC体系结构的支柱。DriverManager不仅仅非常的小巧,而且非常简洁。通过javax.naming和javax.sql这两个标准扩展包,我们可以通过 java 命名和目录接口™ (jndi)命名服务来注册对象去建立数据源的连接的方式去使用数据源。实际上,我们可以使用任何的连接机制,但数据源建议尽可能多地使用对象。
    1. JDBC测试套件 - 这些测试也许不是十分的全面和详尽,但是在JDBC API中执行了很多重要的功能。
    1. JDBC-ODBC Bridge - Java软件桥接可以通过ODBC驱动程序提供JDBC访问。但是需要注意的是,我们需要在使用此驱动程序的每台客户端计算机上加载ODBC二进制代码。因此,ODBC驱动程序最适合于客户端安装不是主要问题的公司网络,或者是以三层架构中的Java编写的应用程序服务器代码。

我们可以使用四个JDBC组件中前两个连接到数据库,然后构建一个Java程序,使用SQL命令去联系和测试关系型数据库。最后两个组件是在一个特定的环境中使用,用于测试Web应用或者是与基于ODBC的DBMS(Database Management System)的通信。

3. JDBC架构

3.1 两层和三层处理模型

图1:数据访问的两层架构

在两层模型中,Java Applet或应用程序直接与数据源进行交互。因此我们需要一个JDBC驱动程序,它可以与被访问的指定的数据源通信,能将用户的命令传递给数据库或者其他的数据源,并且将这些命令的执行结果返回给用户,而这个数据源可能是用户通过网络连接的另外一台计算机上,这种配置方式被称为client/server配置方式。在这种配置方式中,用户的计算机作为客户端,而数据源所在的计算机作为服务端,用于通信的网络可以是可以是内联网,例如连接公司内的员工,也可以是互联网。

图2:数据访问的三层架构

在三层模型中,命令被发送到服务的“中间层”,然后将命令发送到数据源,数据源处理命令并将结果发送回中间层,然后将其发送给用户。三层模型具有很多优势,首先中间层可以保持访问的控制和公司数据类型的更新,然后简化了应用程序的部署,最后,在许多情况下,三层架构可以提供性能优势。

3.2 JDBC API支持数据库访问的两层和三层处理模型

直到最近,中间层经常用C或C ++等语言编写,提供快速的性能。然而,随着将Java字节码转换为特定机器的代码和技术(如Enterprise JavaBeans™)的编译器不断得到优化,Java平台凭借Java的强大、多线程和安全等优势正在迅速成为中间层开发的标准平台。

随着越来越多的企业越来越多地使用Java编程语言来编写服务器代码,JDBC API正在三层架构的中间层中越来越多地被使用,其对连接池、分布式事务和断开连接的行集合的支持这使JDBC成为服务器技术。当然,JDBC API也是允许从Java中间层访问数据源的。

4. 声明

本文翻译自oracle官网并做了部分调整以便于理解,更多信息请访问原文。

转载于:https://www.cnblogs.com/xiao2/p/7193402.html

JDBC学习笔记之JDBC简介相关推荐

  1. JDBC 学习笔记(一)—— 基础知识 + 分页技术

    2019独角兽企业重金招聘Python工程师标准>>> 本文查阅方法:     1.查阅目录 -- 查阅本文目录,确定想要查阅的目录标题     2.快捷"查找" ...

  2. JDBC 学习笔记 day02 用 PreparedStatement 实现 CRUD 操作

    JDBC 学习笔记 day02 PreparedStatement 相比于 Statement 的好处 PreparedStatement 实现 增,删,改 操作 PreparedStatement ...

  3. JDBC学习笔记03【JDBC事务管理、数据库连接池、JDBCTemplate】

    黑马程序员-JDBC文档(腾讯微云)JDBC笔记.pdf:https://share.weiyun.com/Kxy7LmRm JDBC学习笔记01[JDBC快速入门.JDBC各个类详解.JDBC之CR ...

  4. JDBC学习笔记02【ResultSet类详解、JDBC登录案例练习、PreparedStatement类详解】

    黑马程序员-JDBC文档(腾讯微云)JDBC笔记.pdf:https://share.weiyun.com/Kxy7LmRm JDBC学习笔记01[JDBC快速入门.JDBC各个类详解.JDBC之CR ...

  5. JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】

    黑马程序员-JDBC文档(腾讯微云)JDBC笔记.pdf:https://share.weiyun.com/Kxy7LmRm JDBC学习笔记01[JDBC快速入门.JDBC各个类详解.JDBC之CR ...

  6. JDBC学习笔记——Java语言与数据库的鹊桥

    JDBC学习笔记--Java语言与数据库的鹊桥     JDBC(Java DataBase Connectivity):SUN公司提供的 一套操作数据库的标准规范,说白了就是用Java语言来操作数据 ...

  7. JDBC学习笔记(1)---B站尚硅谷宋红康

    JDBC学习笔记(1)-B站尚硅谷宋红康 JDBC学习笔记(2)-B站尚硅谷宋红康 文章目录 软件架构方式介绍 JavaWeb技术概览 第1章:JDBC概述 1.1 数据的持久化 1.2 Java中的 ...

  8. JDBC学习笔记(六)

    JDBC学习笔记(六) Thinkersky[Email:yanghuangming@rongji.com] 关于婚姻与爱情,一组5至10岁的美国小孩给出了他们的答案.也许听起来傻傻的,但是谁能说小娃 ...

  9. StatQuest学习笔记23——RNA-seq简介

    StatQuest学习笔记23--RNA-seq简介 前言--主要内容 这篇笔记是StatQuest系列笔记的第58节,主要内容是讲RNA-seq的原理.StatQuest系列教程的58到62节是协录 ...

最新文章

  1. -变量,进制,数据类型,标识符
  2. 温控自动烘焙系统的研究与实现
  3. 【GStreamer】基本概念及安装
  4. 2016年,你该如何在 Facebook 上做营销?
  5. KVM中ioeventfd创建与触发的大致流程(十四)
  6. 【干货】产品经理的需求管理
  7. 全面讲解Python字典;--什么是字典?字典的常用方法;创建空字典并赋值,增删改查字典中的元素
  8. 《系统集成项目管理工程师》必背100个知识点-11系统集成供应商内部立项的原因和内容
  9. 一篇讲清:数据采集与埋点
  10. QT的QDnsLookup类的使用
  11. jupyter notebook bp网络_全华班再次败北,TES奇葩BP背大锅!签来风哥能拯救滔搏吗?...
  12. c语言十佳运动员有奖评选系统_2019年沃德十佳内饰解读
  13. hadoop使用combiner合并操作
  14. 解决pip2安装不成功的问题
  15. 安装android开发环境
  16. vue设置video图片_vue video和vue-video-player实现视频铺满教程
  17. transition动画无效 iphone6
  18. 罗振宇2017跨年演讲:我们这代人的机会在哪里?
  19. 地址搜索栏设置 极速浏览器
  20. 计算机硬盘写入错误怎么办,永劫无间磁盘写入错误怎么办 磁盘写入错误解决办法...

热门文章

  1. 2007cad多个文件窗口上部排列_【中考信息技术总复习讲义】模块三 操作系统与文件管理...
  2. html5 查看图片,html5实现图片预览和查看原图
  3. 图片添加对话气泡app_刘雨昕、谢可寅、虞书欣代言农夫山泉TOT气泡饮
  4. c语言编2048,c语言编写的2048游戏代码,大家可以参考一下这些
  5. 解决java.net.ConnectException: Connection refused:connect报错
  6. Qt编译报 undefined vtable问题
  7. Linux 运维必备150 个命令,值得收藏!
  8. [翻译] Visual Studio 2019 RC版发布
  9. 用VS2017开发安卓应用
  10. php事务 面向对象,关于PHP面向对象的事务脚本模式