Java JDBC高封装Util类的项目实践

 更新时间:2023年08月20日 08:39:47   作者:AbuLan  
这篇文章主要介绍了Java JDBC高封装Util类的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

Java JDBC高封装Util类

import java.sql.*;
​
public class JdbcUtil {
​
    private static final String URL = "jdbc:mysql://localhost:3306/database?serverTimezone=UTC&useSSL=false";
    private static final String USERNAME = "username";
    private static final String PASSWORD = "password";
​
    private static Connection connection = null;
​
    static {
        try {
            connection = DriverManager.getConnection(URL, USERNAME, PASSWORD);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
​
    public static PreparedStatement getPreparedStatement(String sql, Object... args) throws SQLException {
        PreparedStatement preparedStatement = connection.prepareStatement(sql);
        for (int i = 0; i < args.length; i++) {
            preparedStatement.setObject(i + 1, args[i]);
        }
        return preparedStatement;
    }
​
    public static ResultSet executeQuery(String sql, Object... args) throws SQLException {
        PreparedStatement preparedStatement = getPreparedStatement(sql, args);
        return preparedStatement.executeQuery();
    }
​
    public static int executeUpdate(String sql, Object... args) throws SQLException {
        PreparedStatement preparedStatement = getPreparedStatement(sql, args);
        return preparedStatement.executeUpdate();
    }
​
    public static void close() {
        try {
            if (connection != null && !connection.isClosed()) {
                connection.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

使用方法:

  • 在需要使用JDBC连接的类中导入该util类。
  • getPreparedStatement方法用于获取预编译语句对象并填充参数,返回PreparedStatement对象。
  • executeQuery方法用于执行SELECT语句并返回查询结果集,使用时需要传入SQL语句和占位符参数。
  • executeUpdate方法用于执行增删改操作并返回影响的行数,使用时需要传入SQL语句和占位符参数。
  • 使用完毕后,调用close方法关闭连接。

请注意修改URL、USERNAME和PASSWORD为正确的值。

举例:

假设我们有一个名为users的表,包括id、name和age三个字段。现在要查询出所有用户的姓名,可以这样做:

import java.sql.*;
​
public class Main {
    public static void main(String[] args) {
        try {
            String sql = "SELECT name FROM users";
            ResultSet resultSet = JdbcUtil.executeQuery(sql);
            while (resultSet.next()) {
                String name = resultSet.getString("name");
                System.out.println(name);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            JdbcUtil.close();
        }
    }
}

上述代码中我们调用了JdbcUtil工具类的executeQuery方法来执行SQL查询语句,并获取了查询结果集。然后,我们遍历结果集并打印出各个用户的姓名。

如果需要执行连接关闭操作,则需要在finally块中调用JdbcUtil工具类的close方法来释放连接。

以上仅是一个简单的例子,当然在实际开发中需要更多的参数设置和逻辑控制。

补充:

使用Vector数据结构将查询结果放置到表格控件中。

以下是一个简单的例子,代码中使用了javax.swing包中的JTable和DefaultTableModel类:

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Vector;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;
import java.awt.Dimension;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
​
public class Main {
​
    public static void main(String[] args) {
        try {
            // 执行查询语句
            String sql = "SELECT * FROM users";
            ResultSet resultSet = JdbcUtil.executeQuery(sql);
​
            // 将查询结果封装为Vector数据结构
            Vector<String> columnNames = new Vector<>();
            columnNames.add("id");
            columnNames.add("name");
            columnNames.add("age");
​
            Vector<Vector<Object>> data = new Vector<>();
            while (resultSet.next()) {
                Vector<Object> row = new Vector<>();
                row.add(resultSet.getInt("id"));
                row.add(resultSet.getString("name"));
                row.add(resultSet.getInt("age"));
                data.add(row);
            }
​
            // 创建表格,并设置数据
            DefaultTableModel model = new DefaultTableModel(data, columnNames);
            JTable table = new JTable(model);
​
            // 将表格放置到窗口中
            JFrame frame = new JFrame();
            frame.getContentPane().add(new JScrollPane(table));
            frame.setPreferredSize(new Dimension(500, 300));
            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            frame.pack();
            frame.setVisible(true);
​
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            JdbcUtil.close();
        }
    }
}

在上述代码中,我们将查询结果封装为了一个Vector<Vector<Object>>类型的二维向量,其中外层向量表示所有行,内层向量则表示每一行上的数据,每个内层向量的第一个元素表示"id"列的值,第二个元素表示"name"列的值,第三个元素表示"age"列的值。然后,我们使用DefaultTableModel类将查询结果设置到表格中,并最终将表格放到窗口中以便查看。

此外,需要注意的是,在实际开发中,可能需要对查询结果进行更多的处理和格式控制。这里只是一个简单的使用例子,仅供参考。

到此这篇关于Java JDBC高封装Util类的项目实践的文章就介绍到这了,更多相关Java JDBC封装Util类内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java编程简单获取图片像素的方法

    java编程简单获取图片像素的方法

    这篇文章主要介绍了java编程简单获取图片像素的方法,涉及Java针对图片的读取与属性获取技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • Java一致性Hash算法的实现详解

    Java一致性Hash算法的实现详解

    这篇文章主要介绍了Java一致性Hash算法的实现详解,hash的意思是散列,目的将一组输入的数据均匀的分开、打散,往往用来配合路由算法做负载均衡,多用在分布式系统中,需要的朋友可以参考下
    2024-01-01
  • IKAnalyzer使用不同版本中文分词的切词方式实现相同功能效果

    IKAnalyzer使用不同版本中文分词的切词方式实现相同功能效果

    今天小编就为大家分享一篇关于IKAnalyzer使用不同版本中文分词的切词方式实现相同功能效果,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • Java桥接模式实例详解【简单版与升级版】

    Java桥接模式实例详解【简单版与升级版】

    这篇文章主要介绍了Java桥接模式,结合实例形式分析了java桥接模式简单版与升级版两种实现技巧,需要的朋友可以参考下
    2019-07-07
  • Java装饰者模式的深入了解

    Java装饰者模式的深入了解

    这篇文章主要为大家介绍了Java装饰者模式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • Mybatis敏感数据加解密插件实现过程

    Mybatis敏感数据加解密插件实现过程

    本文介绍了基于MyBatis的敏感数据全链路安全处理方案,包括插件开发原理、具体实现代码以及数据库函数集成,通过MyBatis插件实现自动加解密,结合注解和拦截器技术,确保数据在数据库操作的各个环节中的安全性
    2026-01-01
  • 在Java中将XLS转换为XLSX的实现方案

    在Java中将XLS转换为XLSX的实现方案

    在本文中,我们将探讨传统Excel XLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握高效实现文件格式迁移的方法,需要的朋友可以参考下
    2025-06-06
  • Spring IOC与DI核心重点分析

    Spring IOC与DI核心重点分析

    IOC也是Spring的核心之一了,之前学的时候是采用xml配置文件的方式去实现的,后来其中也多少穿插了几个注解,但是没有说完全采用注解实现。那么这篇文章就和大家分享一下,全部采用注解来实现IOC + DI
    2022-10-10
  • Springboot内置的工具类之CollectionUtils示例讲解

    Springboot内置的工具类之CollectionUtils示例讲解

    这篇文章主要介绍了Springboot内置的工具类之CollectionUtils,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-12
  • 解决springboot上传图片后无法立即访问需重启的问题

    解决springboot上传图片后无法立即访问需重启的问题

    这篇文章主要介绍了解决springboot上传图片后无法立即访问需重启的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12

最新评论