JDBC学习笔记之JDBC简介

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/283069.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PaddleOCR在 windows下的webAPI部署方案

很多小伙伴在使用OCR时都希望能过采用API的方式调用,这样就可以跨端跨平台了。本文将介绍一种基于python的PaddleOCR识方案。喜欢的可以关注公众号,获取更多内容。# 一、 windows环境下部署###1.环境操作系统:windows10;主要软件环…

Vim的NerdTree插件

一个项目文件多起来时,左边的文件树菜单是必要的。参考:常用文件树快捷键所有命令及推荐键盘映射:官方 在vundle插件管理的方式,直接在~/.vimrc中的Plugin段落中加入Plugin "scrooloose/nerdtree"然后重启Vim并输入Plug…

java简单投票系统_JSP实现的简单Web投票程序代码

本文实例讲述了JSP实现的简单Web投票程序。分享给大家供大家参考。具体如下:这里使用文本文件作为数据存储的投票系统。1. vote.java:package vote;import java.io.*;import java.util.*;public class vote {public String filePath "";publi…

HTTP2指纹识别(一种相对不为人知的网络指纹识别方法)

这是关于网络指纹识别的两部分系列的第二部分上一部分我介绍了有关TLS 指纹识别方法(以及在不同客户端的指纹有何区别):https://mp.weixin.qq.com/s/BvotXrFXwYvGWpqHKoj3uQHTTP/2 指纹识别和Tls指纹类似也是一种 Web 服务器可以依赖指纹来识…

中兴智能视觉大数据:人脸识别技术目前处于“用的不够,用的不好”

中兴智能视觉大数据报道:在2018年5月30日举行的“人脸识别等AI技术在校园周边安全中的应用”研讨会上,中国人民大学危机管理研究中心主任唐钧指出,人脸识别等AI技术具有“精细识别”、“提前干预”、“及时处置”等优势,有利于促进…

C#反射,性能优化,不止于优化

“ 架构师的价值,在于独立且理性的思考”想要写出灵活而且具有更好适应性的代码,反射是首选方案。反射赋予程序在运行时动态创建实例的能力,可以在程序运行时(而非编译时)获取实例类型,获取元数据信息&…

设计模式C++实现--Observer模式

2019独角兽企业重金招聘Python工程师标准>>> 观察者模式 当对象间存在一对多关系时,则使用观察者模式(Observer Pattern)。比如,当一个对象被修改时,则会自动通知它的依赖对象。观察者模式属于行为型模式。…

Liunx 安装mysql 5.6.16

2019独角兽企业重金招聘Python工程师标准>>> 1.卸载原有的mysql 1)先查看原有的mysql rpm -qa|grep -i mysql 2)删除 mysql rpm -e --nodeps 包名 3)删除老版本 mysql的开发头文件和库 rm -fr /usr/lib/mysql rm -fr /usr/include/mysql 注意:卸载后/va…

数据挖掘 pandas基础入门之操作

为什么80%的码农都做不了架构师?>>> 统计 import pandas import numpy# 通过传递一个 numpyarray,时间索引以及列标签来创建一个DataFrame: dates pandas.date_range("20180509", periods6) df pandas.DataFrame(num…

C# Task.Delay()和Thread.Sleep()有什么区别?

很多时候我们需要做一段延时处理,就直接Thread.Sleep(n)处理了,但实际上延时也可以用Task.Delay(n),那二者之间有没有区别呢?我们先来看一个案例:using System; using System.Threading; using System.Threading.Tasks…

.NET MAUI实战 MessagingCenter

1.概要在.NET MAUI提供了消息机制,该机制为订阅/发布模式。发布-订阅模式是一种消息传递模式,在此模式下,发布者可在无需知道任何接收方(称为订阅方)的情况下发送消息。同样,订阅方可在不了解任何发布方的情…

洛谷——P1033 自由落体

https://www.luogu.org/problem/show?pid1033#sub 题目描述 在高为 H 的天花板上有 n 个小球,体积不计,位置分别为 0,1,2,….n-1。在地面上有一个小车(长为 L,高为 K,距…

java 接口防刷_java轻量级接口限流/防刷插件

简介call-limit提供接口限流、防刷的功能,插件基于spring开发,在应用应用的任何一个逻辑层皆可使用(web、service、dao),插件支持单机应用下的限流和分布式应用的限流(分布式应用限流需要依赖redis),在简单业务场景下插件可为大家…

【leetcode】521. Longest Uncommon Subsequence I

题目如下: 解题思路:本题有点意思。首先如果输入的两个字符串都为空,那么结果是-1;如果两个字符串长度不一样,那么结果是较长的字符串的长度,因为较长的字符串肯定是自身的子序列,但一定不是较短…

【问题】为什么 System.Timers.Timer 更改间隔时间后的第一次触发时间是设定时间的三倍?...

【问题】为什么 System.Timers.Timer 更改间隔时间后的第一次触发时间是设定时间的三倍?独立观察员 2022 年 9 月 4 日在编写 “Wifi 固定器 [1]” 程序时,按如下方式使用了定时器:// 声明; private Timer _Timer new Timer() { …

JS魔法堂:判断节点位置关系

一、前言                           在polyfill querySelectorAll 和写弹出窗时都需要判断两个节点间的位置关系,通过jQuery我们可以轻松搞定,但原生JS呢?下面我将整理各种判断方法,以供日后查阅。 二…

ChartCtrl源码剖析之——CChartAxis类

CChartAxis类用来绘制波形控件的坐标轴,这个源码相对较复杂,当初阅读的时候耗费了不少精力来理解源码中的一些实现细节。 CChartAxis类的头文件。 #if !defined(AFX_CHARTAXIS_H__063D695C_43CF_4A46_8AA0_C7E00268E0D3__INCLUDED_) #define AFX_CHARTA…

基于.net开发的自助餐饮系统

本文系 EMQ&Intel 联合举办的首届“中国物联网数据基础设施最佳案例评选大赛“个人开发者赛道一等奖作品。项目简介智能餐饮自助结算系统是一个由称重系统、显示屏、自助扫码盒和 Intel CPU 组成的智能自助结算终端,将装有菜品的托盘放到秤盘上结算,…

java打包维护_java打包详解

from yahh2008的blog: http://www.matrix.org.cn/blog/yahh2008/兄弟,对java着迷吗,或者是为了自己的生计,不论怎样都欢迎你进入精彩java世界,welcome!可能你刚刚对每个人说:Hello World!也或者…

Linux高级文本处理之sed(三)

sed高级命令sed允许将多行内容读取到模式空间,这样你就可以匹配跨越多行的内容。本篇笔记主要介绍这些命令,它们能够创建多行模式空间并且处理之。其中,N/D/P这三个多行命令分别对应于小写的n/d/p命令,后者我们在上一篇已经介绍。…