Java JDBC学习教程

news2025/1/11 22:41:53

Java JDBC

  • JDBC 独立于数据库
  • JDBC 不独立于SQL
  • JDBC 不适用于非关系数据库
  • 流行的关系数据库
  • JDBC 教程范围
  • JDBC 核心概念
  • JDBC 示例
  • 加载JDBC驱动程序
  • 打开数据库连接
  • 创建语句
  • 更新数据库
  • 查询数据库
  • 关闭数据库连接

Java JDBC API(Java Database Connectivity)使Java应用程序能够连接到关系数据库,如MySQL、PostgreSQL、MS SQL Server、Oracle、H2数据库等。JDBC API使查询和更新关系数据库以及调用存储过程和获取数据库元数据成为可能。Java JDBC API是核心Java SE SDK的一部分,使所有想要使用JDBC的Java应用程序都可以使用JDBC。下面是一张说明Java应用程序使用JDBC连接到关系数据库的图,Java应用程序使用JDBC连接到数据库:
在这里插入图片描述

JDBC 独立于数据库

Java JDBC API标准化了如何连接到数据库、如何对其执行查询、如何导航此类查询的结果、如何在数据库中执行更新、如何调用存储过程以及如何从数据库中获取元数据。我所说的“标准化”是指代码在不同的数据库产品中看起来是一样的。因此,如果您的项目将来需要,那么更改为另一个数据库会容易得多。

JDBC 不独立于 SQL

JDBC没有对发送到数据库的SQL进行标准化。SQL是由JDBC API的用户也就是我们自己编写的。各种不同数据库使用的SQL方言会略有不同,因此要实现100%数据库独立,SQL还必须100%数据库独立(即使用所有数据库都能理解的命令)。

JDBC 不适用于非关系数据库

Java JDBC API旨在与关系数据库交互,即通过标准SQL进行交互的数据库。JDBC API不适用于Mongo DB、Cassandra、Dynamo等非关系数据库。我们可以从Java应用程序中使用此类数据库,但是我们应该了解这些数据库为Java本身提供了什么驱动程序。

流行的关系数据库

下面列出了一些流行的开源和商业关系数据库,它们具有JDBC驱动程序,因此您可以从Java中使用它们:

  • H2Database
  • MariaDB
  • PostgreSQL
  • Derby
  • Microsoft SQL Server
  • Oracle

JDBC 教程范围

本JDBC教程介绍了Java 8+中可用的JDBC版本。本教程将不涉及JDBC API的每一个细节,而是重点介绍最常用的功能。之后你可以在JavaDoc中阅读其他内容。一旦您对JDBC有了很好的理解,阅读JavaDoc或其他地方的最后细节就不会那么困难了。

本JDBC教程仅介绍JDBC API。它不包括SQL、数据库和数据库设计规则等。如果需要深入研究我们还需要在其他地方研究这些概念。

JDBC 核心概念

Java JDBC API 的核心概念是:

  • JDBC 驱动程序
  • 连接
  • 语句
  • 准备语句
  • 可调用声明
  • 结果集
  • 批量更新
  • 交易
  • 数据库元数据
    这些概念中的每一个都在会在后面的教程中进行了更详细的解释。不过,在下面的部分中,我将简要概述如何使用这些核心组件。然后,当您对JDBC有了基本的了解后,您可以在后面深入学习其他教程。

JDBC 示例

在开始解释JDBC的各个组件如何工作之前,我将向您展示一个完整的JDBC示例,该示例加载JDBC驱动程序、打开数据库连接、创建语句、执行查询并迭代返回的ResultSet:

package com.tianjh;

import java.sql.*;

/**
 * 测试jdbc连接
 *
 * @author tianjh
 * @since 2023-08-22 09:42:14
 */
public class TestJdbc {

    public static void main(String[] args) throws ClassNotFoundException {
        Class.forName("oracle.jdbc.driver.OracleDriver");

        String url = "jdbc:oracle:thin:@127.0.0.1:1522:cs";
        String user = "test";
        String password = "password";

        try (Connection connection = DriverManager.getConnection(url, user, password)) {
            try (Statement statement = connection.createStatement()) {
                String sql = "select * from test";
                try (ResultSet result = statement.executeQuery(sql)) {
                    while (result.next()) {
                        String aac002 = result.getString("aac002");
                        String aac003 = result.getString("aac003");
                    }
                }
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

如果您刚刚接触JDBC不了解这一切,请不要担心。以下示例的每个部分将在以下部分中进行说明。

加载JDBC驱动程序

在Java 6之前,在使用JDBC驱动程序之前必须加载JDBC驱动程序。但在Java 6之后,这应该不再是必要的了。以下是加载Oracle JDBC驱动程序的样子:

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

传递给ClassforName()方法的JavaString参数是给定JDBC驱动程序的JDBC驱动程序类的名称。您必须为正在使用的JDBC驱动程序找到正确的类名。通常,每个数据库都有自己的JDBC驱动程序,因此您必须查找JDBC驱动程序类名(如果您使用的是Java 6之前的版本)。

有几种不同的JDBC驱动程序类型。每种类型都有自己的优点和缺点。您必须了解数据库供应商提供的驱动程序类型。

打开数据库连接

为了与数据库通信,必须首先打开与数据库的JDBC连接。打开JDBC数据库连接在我关于JDBC连接的教程中有更详细的解释,但这里有一个打开JDBC连接的快速示例:

String url = "jdbc:oracle:thin:@127.0.0.1:1522:cs";
String user = "test";
String password = "password";

Connection connection =
    DriverManager.getConnection(url, user, password);

一旦你有了打开的数据库连接,你通常会更新数据库(插入新记录或更新现有记录),或者查询数据库,这意味着你从中读取记录。这两个操作将在下面的章节中简要介绍。

创建语句

无论您需要更新还是查询数据库,都需要创建一个JDBC语句或JDBC PreparedStatement,通过它可以进行更新或查询。以下是创建JDBC语句实例的示例:

Statement statement = connection.createStatement();

更新数据库

创建JDBC语句或JDBC PreparedStatement实例后,可以更新数据库。以下是通过Statement实例更新数据库的示例:

创建 JDBC 或 JDBC 实例后,您可以 更新数据库。下面是通过实例更新数据库的示例:

Statement statement = connection.createStatement();

String    sql       = "update test set name='Tianjh' where id=111";

int rowsAffected    = statement.executeUpdate(sql);

查询数据库

您还可以通过JDBC语句或PreparedStatement对象查询数据库。当您查询数据库时,您会得到一个JDBC ResultSet,通过它您可以访问查询的结果。以下是通过JDBC对数据库执行查询的示例:

Statement statement = connection.createStatement();

String sql = "select * from test";

ResultSet result = statement.executeQuery(sql);

while(result.next()) {

    String name = result.getString("name");
    long   age  = result.getLong  ("age");

}

关闭数据库连接

完成JDBC数据库连接后,必须再次关闭连接。JDBC连接可能占用应用程序内部以及数据库服务器内部的大量资源。因此,在使用后再次关闭数据库连接非常重要。通过JDBC连接的close()方法关闭JDBC连接。下面是一个关闭JDBC连接的示例:

connection.close();

在我的JDBC连接教程中,关闭JDBC连接部分也详细介绍了关闭JDBC连接。

下一篇: JDBC概述

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

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

相关文章

无涯教程-PHP - preg_grep()函数

preg_grep() - 语法 array preg_grep ( string $pattern, array $input [, int $flags] ); 返回由与给定模式匹配的输入数组元素组成的数组。 如果将flag设置为PREG_GREP_INVERT,则此函数返回输入数组中与给定模式不匹配的元素。 preg_grep() - 返回值 返回使用…

8路光栅尺磁栅尺编码器或16路高速DI脉冲信号转Modbus TCP网络模块 YL99-RJ45

特点: ● 光栅尺磁栅尺解码转换成标准Modbus TCP协议 ● 高速光栅尺磁栅尺4倍频计数,频率可达5MHz ● 模块可以输出5V的电源给光栅尺或传感器供电 ● 支持8个光栅尺同时计数,可识别正反转 ● 可以设置作为16路独立DI高速计数器 ● 可网…

vue 简单实验 v-bind 变量与html属性绑定

1.代码 <script src"https://unpkg.com/vuenext" rel"external nofollow" ></script> <div id"bind-attribute"><span v-bind:title"message">鼠标悬停几秒钟查看此处动态绑定的提示信息&#xff01;</sp…

“产业应用创新奖2023”启动征集

当前&#xff0c;人工智能已经成为新一轮科技革命和产业变革的重要驱动力量&#xff0c;基于强算法、大算力和大数据的大模型成为主流方向。文心大模型和飞桨一直致力于发挥算法模型技术优势&#xff0c;助力AI 大生产加速升级。 文心飞桨赋能千行百业 产业创新不断涌现 数字医…

你做的可视化大屏老被老板嫌弃丑?那是你没掌握这7个动态效果!

数据可视化大屏成为了最近的爆火需求&#xff0c;自从老李我在朋友圈发了一条关于可视化大屏的朋友圈&#xff0c;客户、亲戚、朋友、同学都过来问我这种可视化大屏是怎么做出来的&#xff0c;要花多少钱&#xff1f; 老李也很实诚&#xff0c;直接跟他们说&#xff0c;免费&a…

概率论与数理统计:第七章:参数估计 第八章:假设检验

文章目录 Ch7. 参数估计7.1 点估计1.矩估计2.最大似然估计(1)离散型(2)连续型 7.2 评价估计量优良性的标准(1)无偏性 (无偏估计)(2)有效性(3)一致性 7.3 区间估计1.置信区间、置信度2.求μ的置信区间 Ch8. 假设检验1.拒绝域α、接受域1-α、H₀原假设、H₁备择假设2.双边检验、…

初识 JVM 01

JVM JRE JDK的关系 JVM 的内存机构 程序计数器 java指令的执行流程&#xff1a; 1 右侧的java源代码编译为左侧的java字节码&#xff08;右侧第一个方块对应左侧第一个方块&#xff09; 2 字节码 经过解释器 变为机器码 3 机器码就可以被cpu来执行 程序计数器的作用就…

Linux学习之samba服务

yum install -y samba安装samba。 安装完成如下&#xff1a; /etc/samba/smb.conf是samba配置文件&#xff0c;内容如下&#xff1a; # See smb.conf.example for a more detailed config file or # read the smb.conf manpage. # Run testparm to verify the config is cor…

亿发智能定制系统规范食品饮料行业质量管理,ERP解决方案助力业务增长

随着食品生产业态的不断复杂化和食品风险的逐渐凸显&#xff0c;食品饮料生产商面临着更大的挑战和机遇,需要与时俱进&#xff0c;借助数字化手段建立完整的质量管理体系&#xff0c;有效降低食品事故的风险。同时&#xff0c;面对数字化时代&#xff0c;食品饮料生产商需要一套…

正则表达式一小时学完

闯关式学习Regex 正则表达式&#xff0c;我感觉挺不错的&#xff0c;记录一下。 遇到不会的题&#xff0c;可以评论交流。 真的很不错 链接 Regex Learn - Step by step, from zero to advanced.

ui设计师年终总结(合集)

ui设计师年终总结篇一 xx年很快就会过去了&#xff0c;掐指一算&#xff0c;来到同程已经整整一年了&#xff0c;在这里我对我一年以来的工作情况进行简要的总结&#xff0c;算是对公司也是对个人这段时间的工作的一个交代&#xff0c;详细内容请看下文ui设计师年终个人总结。…

快速上手Linux核心命令:文件内容相关命令

前言 上一篇中已经预告&#xff0c;我们这篇主要说一说Linux中文件内容查看处理相关的命令。一共16个命令&#xff0c;其中 标注的为重点命令&#xff0c;工作中用的也比较多&#xff0c;需要熟练掌握 cat 合并文件或查看文件内容 1、简介 cat 是concatenate 单词的缩写&a…

仿mudou高性能高并发服务器

"这个结局是我的期待&#xff0c;我会一直为你祝福。" 项目实现目标: 仿muduo库One Thread One Loop式主从Reacto模型实现高并发服务器。通过实现高并发服务器组件&#xff0c;简洁快速完成搭建一个高性能服务器。并且&#xff0c;通过组件内提供的不同应⽤层协议⽀…

LeetCode108. 将有序数组转换为二叉搜索树

108. 将有序数组转换为二叉搜索树 一、题目 给你一个整数数组 nums &#xff0c;其中元素已经按 升序 排列&#xff0c;请你将其转换为一棵 高度平衡 二叉搜索树。 高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。 示例 1&#x…

报错sql_mode=only_full_group_by

首发博客地址 https://blog.zysicyj.top/ 报错内容 ### The error may exist in file[D:\code\cppCode20221025\leader-system\target\classes\mapper\system\TJsonDataMapper.xml] ### The error may involve defaultParameterMap ### The error occurred while…

用Cmake build OpenCV后,在VS中查看OpenCV源码的方法(环境VS2022+openCV4.8.0) Part I

用Cmake build OpenCV后&#xff0c;在VS中查看OpenCV源码的方法 Part I 本文打算分成两部分写&#xff1a; 第一部分力求用最简单的办法帮助大家直接在VS中查看OpenCV的源码。这种方法最大的优点就是不容易出错&#xff0c;且操作简单。如果只是需要查看OpenCV源码的同学&…

2.类加载子系统

小碎碎&#xff1a;春风若有怜花意&#xff0c;可否许我再少年。 内存结构概述 ● Class文件 ● 类加载子系统 ● 运行时数据区 ○ 方法区 ○ 堆 ○ 程序计数器 ○ 虚拟机栈 ○ 本地方法栈 ● 执行引擎 ● 本地方法接口 ● 本地方法库 小记 LV : local values 本地&#xff0…

C++day2作业(2023.8.22)

1.定义一个学生的结构体&#xff0c;包含学生的姓名&#xff0c;年龄&#xff0c;成绩&#xff0c;性别&#xff0c;学生的成绩&#xff0c;姓名&#xff0c;定义为私有权限&#xff1b;定义一个学生类型的结构体变量&#xff0c;设置公有函数用于给学生的成绩和名字进行赋值&a…

【AIGC】一款离线版的AI智能换脸工具V2.0分享(支持图片、视频、直播)

随着人工智能技术的爆发&#xff0c;AI不再局限于大语言模型&#xff0c;在图片处理方面也有非常大的进步&#xff0c;其中AI换脸也是大家一直比较感兴趣的&#xff0c;但这个技术的应用一直有很大的争议。 今天给大家分享一个开源你的AI换脸工具2.0&#xff0c;只需要一张所需…