Java JDBC连接数据库常见操作总结

yizhihongxing

Java JDBC连接数据库常见操作总结

JDBC介绍

Java 数据库连接 (Java Database Connectivity, JDBC) 是一种用于执行 SQL 语句的 Java API,可以为多个关系数据库提供统一访问,它由一组用 Java 语言编写的类和接口组成,可以使 Java 应用程序轻松地访问数据库。

JDBC 本质上是通过 JNI(Java Native Interface)来调用本地代码实现的。这些本地代码组成的库被称作 JDBC 驱动程序(JDBC Driver)。JDBC 主要分为四个部分:JDBC 驱动管理器、JDBC 驱动程序、JDBC API 和 JDBC 数据库的连接。

JDBC连接数据库

使用 JDBC 连接数据库只需以下几步:

  • 导入 JDBC 驱动包:需要将 JDBC 驱动包放到 CLASSPATH 中,否则程序无法找到 JDBC 驱动。
  • 加载 JDBC 驱动程序:可以使用 Class.forName() 方法来加载 JDBC 驱动,例如加载 MySQL 驱动的代码为:Class.forName("com.mysql.jdbc.Driver");
  • 获取数据库连接对象:使用 DriverManager.getConnection() 方法获取数据库连接对象,需要传入数据库 URL、用户名和密码。
  • 执行 SQL 语句:可以使用 Statement 或 PreparedStatement 对象执行 SQL 语句。
  • 处理查询结果:使用 ResultSet 对象处理查询结果。

下面我们将通过两个示例说明如何连接数据库。

示例1:连接 MySQL 数据库

步骤1:导入 JDBC 驱动包

假设我们使用 MySQL 数据库,需要先下载 MySQL 的 JDBC 驱动包,下载地址为:https://dev.mysql.com/downloads/connector/j/。将下载得到的 JDBC 驱动包放到项目的 lib 目录下。

步骤2:加载 JDBC 驱动程序

加载 MySQL 驱动的代码为:

Class.forName("com.mysql.jdbc.Driver");

步骤3:获取数据库连接对象

获取 MySQL 数据库连接对象的代码为:

String url = "jdbc:mysql://localhost:3306/test?useSSL=false";
String user = "root";
String password = "123456";
Connection conn = DriverManager.getConnection(url, user, password);

其中,url 是连接字符串,test 是数据库名称,root 是用户名,123456 是密码。这里的 useSSL=false 表示不使用 SSL 连接。

步骤4:执行 SQL 语句

假设我们要执行一条查询语句,查询表中的所有数据,代码如下:

Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM user");

步骤5:处理查询结果

我们可以使用 ResultSet 对象处理查询结果,代码如下:

while (rs.next()) {
    int id = rs.getInt("id");
    String name = rs.getString("name");
    String email = rs.getString("email");
    System.out.println(id + "\t" + name + "\t" + email);
}

完整的示例代码如下:

import java.sql.*;

public class MySQLDemo {
    public static void main(String[] args) throws Exception {
        Class.forName("com.mysql.jdbc.Driver");

        String url = "jdbc:mysql://localhost:3306/test?useSSL=false";
        String user = "root";
        String password = "123456";
        Connection conn = DriverManager.getConnection(url, user, password);

        Statement stmt = conn.createStatement();
        ResultSet rs = stmt.executeQuery("SELECT * FROM user");
        while (rs.next()) {
            int id = rs.getInt("id");
            String name = rs.getString("name");
            String email = rs.getString("email");
            System.out.println(id + "\t" + name + "\t" + email);
        }

        rs.close();
        stmt.close();
        conn.close();
    }
}

输出结果为:

1   Alice   alice@example.com
2   Bob bob@example.com
3   Carol   carol@example.com

示例2:连接 Oracle 数据库

步骤1:导入 JDBC 驱动包

假设我们使用 Oracle 数据库,需要先下载 Oracle 的 JDBC 驱动包,下载地址为:http://www.oracle.com/technetwork/database/features/jdbc/default-2280470.html。将下载得到的 JDBC 驱动包放到项目的 lib 目录下。

步骤2:加载 JDBC 驱动程序

加载 Oracle 驱动的代码为:

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

步骤3:获取数据库连接对象

获取 Oracle 数据库连接对象的代码为:

String url = "jdbc:oracle:thin:@localhost:1521:orcl";
String user = "scott";
String password = "tiger";
Connection conn = DriverManager.getConnection(url, user, password);

其中,url 是连接字符串,localhost 是主机名,1521 是端口号,orcl 是数据库实例名。这里的 thin 表示用 thin 驱动连接,@ 后面的 : 表示用冒号隔开,依次是主机名、端口号和数据库实例名。

步骤4:执行 SQL 语句

假设我们要执行一条查询语句,查询表中的所有数据,代码如下:

Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM emp");

步骤5:处理查询结果

我们可以使用 ResultSet 对象处理查询结果,代码如下:

while (rs.next()) {
    int empno = rs.getInt("empno");
    String ename = rs.getString("ename");
    String job = rs.getString("job");
    System.out.println(empno + "\t" + ename + "\t" + job);
}

完整的示例代码如下:

import java.sql.*;

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

        String url = "jdbc:oracle:thin:@localhost:1521:orcl";
        String user = "scott";
        String password = "tiger";
        Connection conn = DriverManager.getConnection(url, user, password);

        Statement stmt = conn.createStatement();
        ResultSet rs = stmt.executeQuery("SELECT * FROM emp");
        while (rs.next()) {
            int empno = rs.getInt("empno");
            String ename = rs.getString("ename");
            String job = rs.getString("job");
            System.out.println(empno + "\t" + ename + "\t" + job);
        }

        rs.close();
        stmt.close();
        conn.close();
    }
}

输出结果为:

7369    SMITH   CLERK
7499    ALLEN   SALESMAN
7521    WARD    SALESMAN
7566    JONES   MANAGER
7654    MARTIN  SALESMAN
7698    BLAKE   MANAGER
7782    CLARK   MANAGER
7788    SCOTT   ANALYST
7839    KING    PRESIDENT
7844    TURNER  SALESMAN
7876    ADAMS   CLERK
7900    JAMES   CLERK
7902    FORD    ANALYST
7934    MILLER  CLERK

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java JDBC连接数据库常见操作总结 - Python技术站

(0)
上一篇 2023年6月16日
下一篇 2023年6月16日

相关文章

  • java 异常详解及应用实例

    Java 异常详解及应用实例 Java 是一种强类型语言,它强制要求程序员在开发过程中必须处理所有可能发生的异常。Java 提供了异常机制来处理错误并正确退出程序。在该文中,我们将详细介绍 Java 异常的使用和应用实例。 异常的概念和机制 Java 中的异常指程序在执行过程中出现的不正常情况或错误,如数组越界、除数为零等情况。当程序执行发生异常时,JVM …

    Java 2023年5月27日
    00
  • 关于Maven混合配置私有仓库和公共仓库的问题

    这里是一份关于Maven混合配置私有仓库和公共仓库的完整攻略: 1. 添加私有仓库 如果你想要将私有仓库添加到你的Maven配置中,可以按照以下步骤: 1.1. 在pom.xml中添加私有仓库 将以下代码添加到你的pom.xml中,替换${私有仓库地址}为你的私有仓库地址: <repositories> <repository> &l…

    Java 2023年5月20日
    00
  • 为Java程序员准备的10分钟Perl教程

    为Java程序员准备的10分钟Perl教程是一份旨在通过简短的教学来为Java程序员介绍Perl的基础知识的文档。下面是一份完整攻略: 简介 在这份教程中,我们将学习Perl的基础知识。Perl是一种通用的脚本语言,特别适合快速开发。Perl有一个庞大的社区以及丰富的文档和库。 变量 在Perl中声明变量不需要指定类型。变量的类型会随着所存储的数据类型而变化…

    Java 2023年5月23日
    00
  • Java 实现浏览器下载文件及文件预览

    下面是 Java 实现浏览器下载文件及文件预览的完整攻略。 1. 下载文件 1.1 从网络上下载文件 Java 中可以使用 URLConnection 和 HttpURLConnection 类实现从网络上下载文件,具体方法如下: import java.io.*; import java.net.HttpURLConnection; import java…

    Java 2023年5月19日
    00
  • Springmvc如何实现向前台传递数据

    下面是Spring MVC向前台传递数据的完整攻略。 1. 了解Spring MVC架构 在Spring MVC中,前台的请求被DispatcherServlet(前端控制器)拦截处理,控制器接收请求,处理请求,然后返回ModelAndView对象给DispatcherServlet,再由DispatcherServlet返回给前台视图。因此,我们可以使用M…

    Java 2023年6月15日
    00
  • Java基础之文件概述

    现在我来详细讲解一下Java基础之文件概述的完整攻略。 什么是文件? 首先,我们来了解一下什么是文件。文件是存储在计算机上的数据结构,可以是文本文件、图片文件、音频文件等等。在Java中,文件是由字节流或字符流读写的,这取决于文件的类型。 文件的基本操作 Java中常用的文件操作包括创建文件、读取文件、写入文件和删除文件。下面分别进行详细讲解。 创建文件 要…

    Java 2023年5月20日
    00
  • java之File对象对文件的操作常用的几个方法(推荐)

    Java之File对象对文件的操作常用的几个方法 在Java中,我们可以使用File类来操作文件和目录。File类提供了许多常用的方法,本篇文章将介绍File对象对文件的操作常用的几个方法。 1. 创建文件 我们可以使用File类的createNewFile()方法来创建文件。该方法创建一个新的,为空的文件,如果文件已经存在则返回false。 import …

    Java 2023年5月20日
    00
  • 微信小程序实现电子签名功能

    下面详细讲解“微信小程序实现电子签名功能”的完整攻略。 1. 电子签名功能介绍 电子签名是指在电子文档、电子表格等电子化的文件上,用特殊的电子签名技术来确认文件的真实性、完整性、不可抵赖性以及签署人身份的唯一性。在企业、政府等机构中广泛使用,实现了纸质文件的电子化处理,提高了效率和安全性。 2. 实现电子签名的基本原理 实现电子签名的基本原理是通过对签名人的…

    Java 2023年5月30日
    00
合作推广
合作推广
分享本页
返回顶部