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

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日

相关文章

  • weblogic服务建立数据源连接测试更新mysql驱动包的问题及解决方法

    WebLogic服务建立数据源连接测试 为了使WebLogic Server能够连接到数据库中的数据,您需要在WebLogic Server上设置数据源。以下是设置数据源的步骤: 步骤1:登录WebLogic控制台 首先,您需要打开WebLogic Server的管理控制台。在Web浏览器中输入URL(如http://localhost:7001/conso…

    Java 2023年5月20日
    00
  • 如何实现线程安全的算法?

    以下是关于线程安全的算法的完整使用攻略: 什么是线程安全的算法? 线程安全的算法是指在多线程环境下,多个线程可以同时访问算法而不会出现数据不一致或程序崩溃等问题。在线程编程中,线程安全的算法是非常重要的,因为多个线程同时访问算法,会出现线程争用的问题,导致数据不一致或程序崩溃。 如何实现线程安全的算法? 为实现线程安全的算法需要使用同步机制来保证多线程对算法…

    Java 2023年5月12日
    00
  • java实现建造者模式(Builder Pattern)

    下面我就详细讲解一下“Java实现建造者模式(Builder Pattern)”的完整攻略。 什么是建造者模式? 建造者模式是一种对象创建型设计模式,它允许你创建不同风格的对象,同时避免构造器污染问题。在该模式中,我们将构造过程分步进行,使得在创建对象时能够更加灵活地控制每个构造步骤,从而创建不同类型的对象。 建造者模式的角色 建造者模式中有以下几个角色: …

    Java 2023年5月18日
    00
  • SpringBoot返回多种格式的数据的实现示例

    在 Spring Boot 中,我们可以使用多种方式返回不同格式的数据,例如 JSON、XML、HTML 等。在本文中,我们将详细讲解 Spring Boot 返回多种格式的数据的实现示例。 示例一:返回 JSON 格式的数据 以下是一个示例,演示如何在 Spring Boot 中返回 JSON 格式的数据: 创建一个名为 UserController 的控…

    Java 2023年5月15日
    00
  • AOP之事务管理的两种配置方式

    对于AOP之事务管理的两种配置方式,我们可以使用以下两种方式进行配置: 一、使用标签配置事务管理 1. 在XML配置文件中声明TransactionManager代理 <!– 声明 TransactionManager bean –> <bean id="txManager" class="org.spri…

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

    当涉及到微信小程序实现电子签名时,你需要考虑的几个方面包括: 1.实现方式:使用canvas绘制签名区域并导出图片保存。2.显示签名:使用Image组件或canvas绘制签名。3.文档验证:签名本身并不具有验证功能,需要合适的过程和算法确保签名的安全性。 接下来,我将详细讲解实现电子签名的完整攻略。 步骤1:创建签名区域 要在小程序中实现签名,你需要在页面上…

    Java 2023年5月23日
    00
  • Springboot整合企业微信机器人助手推送消息的实现

    什么是企业微信机器人助手? 企业微信机器人助手是企业微信推出的一款机器人应用,旨在方便企业在企业微信中进行消息推送、管理和协作等操作。企业微信机器人助手可以通过API接口,实现与企业自有的应用进行对接。 Springboot整合企业微信机器人助手的实现过程 下面我们来讲一下如何在Springboot中整合企业微信机器人助手,实现推送消息的功能。 2.1 准备…

    Java 2023年5月20日
    00
  • SpringBoot集成Jpa对数据进行排序、分页、条件查询和过滤操作

    下面是关于“SpringBoot集成Jpa对数据进行排序、分页、条件查询和过滤操作”的完整攻略。 简介 首先,SpringBoot是一个基于Spring框架的快速开发框架。而Jpa则是Java持久层API的规范,通过使用Jpa规范,我们可以很方便地实现与数据库的交互。本文主要介绍如何使用SpringBoot集成Jpa,对数据进行排序、分页、条件查询和过滤操作…

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