制作简单的JdbcEasyUseUtils

制作简单的JdbcEasyUseUtils

package jdbc;

import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Field;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;

/**
 * @author 小邱
 * @version 0.0.1
 * @description JdbcEasyUseUtils Jdbc功能封装类
 * 使用之前需要在resources中创建jdbc.properties文件,
 * 且至少包含username、password、url、driverClassName属性
 * @since 2021/9/28 14:05
 */
public class JdbcEasyUseUtils {
    /**
     * 实现增删改操作
     * @param sql 要执行的sql语句
     * @param args sql语句中占位符依次对应的参数
     */
    public static void update(String sql, Object... args){
       Connection connection = null;
       PreparedStatement ps = null;
       try {
           //获取连接
           connection = JdbcEasyUseUtils.getConnection();
           //预编译sql语句
           ps = connection.prepareStatement(sql);
           //填充占位符(占位符从1开始)
           for (int i = 0; i < args.length; i++) {
               ps.setObject(i+1, args[i]);
           }
           //执行sql语句
           ps.execute();
       } catch (SQLException throwables) {
           throwables.printStackTrace();
       } finally {
           //关闭资源
           JdbcEasyUseUtils.close(connection, ps);
       }
   }

    /**
     * 针对不同表查询返回多条数据
     * @param clazz 要返回的类
     * @param sql 要查询的sql语句
     * @param args sql语句中占位符依次对应的参数
     * @param <T> 要返回的类
     * @return 返回一个封装多个对象的list
     */
    public static <T> List<T> queryMore(Class<T> clazz, String sql, Object... args) {
        Connection connection = null;
        PreparedStatement ps = null;
        ResultSet rs = null;
        try {
            //获取连接
            connection = JdbcEasyUseUtils.getConnection();
            //预编译sql
            ps = connection.prepareStatement(sql);
            //填充占位符
            for (int i = 0; i < args.length; i++) {
                ps.setObject(i + 1, args[i]);
            }
            //执行sql得到返回集
            rs = ps.executeQuery();
            //获取结果集的元数据(表头)
            ResultSetMetaData metaData = rs.getMetaData();
            //通过元数据获取结果集列数
            int columnCount = metaData.getColumnCount();
            //创建集合对象
            ArrayList<T> list = new ArrayList<>();
            //处理结果集,对每行数据分别封装到对象
            while (rs.next()) {
                //创建对象
                T t = clazz.newInstance();
                //对每一行数据进行封装到对象
                for (int i = 0; i < columnCount; i++) {
                    //通过结果集获取结果集的每个列列值
                    Object value = rs.getObject(i + 1);

                    //通过元数据调用getColumnLabel获取结果集每个列的别名(别名要与JavaBean属性名对应),若sql语句中没取别名则获取列名,此时JavaBean属性名与数据库字段名可以不一致
                    String columnName = metaData.getColumnLabel(i + 1);

                    //通过反射给User对象指定的columnName赋值value
                    //通过反射获取属性
                    Field field = clazz.getDeclaredField(columnName);
                    //修改成可赋值
                    field.setAccessible(true);
                    //赋值
                    field.set(t, value);
                }
                //把每个对象添加到集合中
                list.add(t);

            }
            //返回集合
            return list;
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JdbcEasyUseUtils.close(connection, ps, rs);
        }
        return null;

    }
    /**
     * 针对不同表查询返回一条记录
     * @param clazz 要返回的类
     * @param sql 要查询的sql语句
     * @param args sql语句中占位符依次对应的参数
     * @param <T> 要返回的类
     * @return 返回一条记录封装的对象
     */
    public static <T> T queryOne(Class<T> clazz, String sql, Object... args) {
        Connection connection = null;
        PreparedStatement ps = null;
        ResultSet rs = null;
        try {
            //获取连接
            connection = JdbcEasyUseUtils.getConnection();
            //预编译sql
            ps = connection.prepareStatement(sql);
            //填充占位符
            for (int i = 0; i < args.length; i++) {
                ps.setObject(i + 1, args[i]);
            }
            //执行sql得到返回集
            rs = ps.executeQuery();
            //获取结果集的元数据(表头)
            ResultSetMetaData metaData = rs.getMetaData();
            //通过元数据获取结果集列数
            int columnCount = metaData.getColumnCount();
            //处理结果集,该条结果读取columnCount个数据
            if (rs.next()) {
                //创建对象
                T t = clazz.newInstance();
                for (int i = 0; i < columnCount; i++) {
                    //通过结果集获取结果集的每个列列值
                    Object value = rs.getObject(i + 1);

                    //通过元数据调用getColumnLabel获取结果集每个列的别名(别名要与JavaBean属性名对应),若sql语句中没取别名则获取列名,此时JavaBean属性名与数据库字段名可以不一致
                    String columnName = metaData.getColumnLabel(i + 1);

                    //通过反射给对象指定的columnName赋值value
                    //通过反射获取属性
                    Field field = clazz.getDeclaredField(columnName);
                    //修改成可赋值
                    field.setAccessible(true);
                    //赋值
                    field.set(t, value);
                }
                return t;
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JdbcEasyUseUtils.close(connection, ps, rs);
        }
        return null;

    }

    //获取连接
    public static Connection getConnection() {
        Connection connection = null;
        try {
            //加载配置文件
            InputStream resource = JdbcPreparedStatementTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
            Properties properties = new Properties();
            properties.load(resource);
            //获取配置文件属性
            String username = properties.getProperty("username");
            String password = properties.getProperty("password");
            String url = properties.getProperty("url");
            String driverClassName = properties.getProperty("driverClassName");
            //加载驱动
            Class.forName(driverClassName);
            //获取连接
            connection = DriverManager.getConnection(url, username, password);
        } catch (IOException | ClassNotFoundException | SQLException e) {
            e.printStackTrace();
        }
        return connection;
    }

    //关闭资源
    public static void close(Connection connection, Statement statement) {
        try {
            if (connection != null) {
                connection.close();
            }
            if (statement != null) {
                statement.close();
            }
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }


    }

    //关闭资源
    public static void close(Connection connection, Statement statement, ResultSet resultSet) {
        try {
            if (connection != null) {
                connection.close();
            }
            if (statement != null) {
                statement.close();
            }
            if (resultSet != null) {
                resultSet.close();
            }
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }


    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值