java的jdbc简单封装方法

下面是完整的“java的jdbc简单封装方法”的攻略。

背景介绍

Java连接数据库可以使用JDBC API实现。但是,JDBC API的一些操作非常繁琐,比如数据库连接的建立和关闭、一些查询操作和结果集的处理等。这些繁琐的操作增加了我们代码的复杂度。考虑此问题,我们可以对JDBC API进行简单封装来降低代码的复杂度。

简单封装实现

步骤1:引入依赖

我们需要引入 JDBC 驱动程序依赖,这里以 MySQL 为例。

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>版本号</version>
</dependency>

步骤2:定义封装类

定义一个类,封装JDBC操作,我们可以将代码中常用的操作封装到这个类中,这样就可以屏蔽掉之前提到的一些繁琐的操作。下面是一个简单的例子,我们封装了JDBC操作中的连接打开、关闭、查询和更新语句执行功能。

import java.sql.*;

public class JdbcUtils {
    private static final String URL = "jdbc:mysql://localhost:3306/test_db";
    private static final String USER_NAME = "root";
    private static final String PASSWORD = "123456";
    private static Connection conn;

    static {
        try {
            Class.forName("com.mysql.jdbc.Driver");
            conn = DriverManager.getConnection(URL, USER_NAME, PASSWORD);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static Connection getConnection() {
        return conn;
    }

    public static void close(Connection conn, PreparedStatement pstmt, ResultSet rs) {
        try {
            if (rs != null) {
                rs.close();
            }
            if (pstmt != null) {
                pstmt.close();
            }
            if (conn != null) {
                conn.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public static ResultSet query(String sql, Object... params) throws SQLException {
        PreparedStatement pstmt = conn.prepareStatement(sql);
        if (params != null) {
            for (int i = 0; i < params.length; i++) {
                pstmt.setObject(i + 1, params[i]);
            }
        }
        return pstmt.executeQuery();
    }

    public static int update(String sql, Object... params) throws SQLException {
        PreparedStatement pstmt = conn.prepareStatement(sql);
        if (params != null) {
            for (int i = 0; i < params.length; i++) {
                pstmt.setObject(i + 1, params[i]);
            }
        }
        return pstmt.executeUpdate();
    }
}

步骤3:使用封装类

在需要使用JDBC操作时,只需要调用封装类中的方法就可以了。下面是两个简单的例子,一个是查询操作,另一个是更新操作。

查询

public class TestQuery {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            conn = JdbcUtils.getConnection();
            String sql = "SELECT * FROM users WHERE username = ?";
            pstmt = conn.prepareStatement(sql);
            pstmt.setString(1, "Tom");
            rs = JdbcUtils.query(sql, "Tom");
            while (rs.next()) {
                System.out.println(rs.getString("username") + " " + rs.getString("password"));
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            JdbcUtils.close(conn, pstmt, rs);
        }
    }
}

更新

public class TestUpdate {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement pstmt = null;
        try {
            conn = JdbcUtils.getConnection();
            String sql = "UPDATE users SET password = ? WHERE username = ?";
            pstmt = conn.prepareStatement(sql);
            pstmt.setString(1, "123456");
            pstmt.setString(2, "Tom");
            int result = JdbcUtils.update(sql, "123456", "Tom");
            System.out.println(result);
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            JdbcUtils.close(conn, pstmt, null);
        }
    }
}

总结

本文介绍了如何利用封装技术来简化 JDBC API 的使用,封装后的代码更加简洁易读,可以提高开发效率。通过以上示例的讲解,相信大家已经掌握了 jdbc 的简单封装方法。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:java的jdbc简单封装方法 - Python技术站

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

相关文章

  • 如何把本地jar包导入maven并pom添加依赖

    下面是如何把本地jar包导入maven并pom添加依赖的完整攻略: 1. 将本地jar包导入maven仓库 使用本地jar包,我们需要先将其导入maven仓库里面,这样我们才能在pom文件中引用到它。 步骤如下: 打开命令行窗口,进入到本地jar包所在目录 假设本地jar包文件名为example.jar,执行以下命令: shell mvn install:i…

    Java 2023年5月20日
    00
  • Struts2学习教程之Action类如何访问WEB资源

    为了让Action类能够访问WEB资源,需要进行以下几个步骤: 1. 在struts.xml中进行配置 在struts.xml中需要配置一个<constant>元素,设置resourceBase属性为需要访问的WEB资源的路径。 示例代码: <constant name="struts.convention.result.path…

    Java 2023年5月20日
    00
  • Java中高效判断数组中是否包含某个元素的几种方法

    下面来详细讲解Java中高效判断数组中是否包含某个元素的几种方法。 问题描述 在Java中的开发中经常需要判断一个数组中是否包含某个元素,这是一个非常常见的需求。但是在实践中,我们需要选择高效的方法来完成这个任务,以尽快地得到结果,提高程序的运行效率和响应速度。 方法一:使用循环判断 使用循环逐一遍历数组中的元素,对每个元素和目标元素进行比较,如果相同,则说…

    Java 2023年5月26日
    00
  • Java如何判断整数溢出,溢出后怎么得到提示

    Java中整数类型(int, long等)变量的范围是有限的,当一个变量的数值超出了它的范围时,就会发生整数溢出。溢出的结果与数值运算的结果不同,可能导致程序运行异常,所以我们需要在程序中判断整数是否溢出,并得到提示以确保程序的正确性。 判断整数溢出的方法是通过与最值的比较来实现的。以int类型的整数为例,最大值为2^31-1(即2147483647),最小…

    Java 2023年5月25日
    00
  • java文件的简单读写操作方法实例分析

    Java文件的简单读写操作方法实例分析 在 Java 程序开发中,我们经常需要对文件进行读写操作。本篇攻略将详细介绍 Java 文件读写的方法以及相关注意事项。 文件读取操作 在 Java 中,我们可以使用 FileInputStream 和 BufferedInputStream 类来读取文件。 FileInputStream import java.io…

    Java 2023年5月20日
    00
  • Java读取数据库表

    Java读取数据库表 package com.easycrud.builder; import com.easycrud.utils.PropertiesUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.sql.*; /** * @BelongsProjec…

    Java 2023年5月2日
    00
  • java的Hibernate框架报错“UnresolvableObjectException”的原因和解决方法

    当使用Hibernate框架时,可能会遇到“UnresolvableObjectException”错误。这个错误通常是由于以下原因之一引起的: 对象不存在:如果您尝试加载一个不存在的对象,则可能会出现此错误。在这种情况下,需要确保您的对象存在于数据库中。 对象已被删除:如果您尝试加载一个已被删除的对象,则可能会出现此错误。在这种情况下,需要确保您的对象未被…

    Java 2023年5月4日
    00
  • java对象数组实现学生信息管理系统

    Java对象数组实现学生信息管理系统攻略 在Java中,我们可以使用对象数组来实现一个学生信息管理系统。我们可以将学生信息作为一个对象,使用对象数组来存储多个学生的信息。下面是实现学生信息管理系统的完整攻略。 1. 定义学生信息类 我们首先需要定义一个学生信息类,用于存储学生的信息,包括姓名、年龄、性别、学号等。以下是一个示例: public class S…

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