BaseDao封装增删改查(超详解!)

Hi i,m JinXiang


⭐ 前言 ⭐

本篇文章主要介绍对数据库中表中的数据进行增改删查询,封装一个工具类(BaseDao)的详细使用以及部分理论知识


🍉欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁

🍉博主收将持续更新学习记录获,友友们有任何问题可以在评论区留言


目录

一、什么是BaseDao?

BaseDao的优点:

1、代码复用

2、统一管理

3、提高开发效率

4、提供扩展性

5、降低耦合性

二、BaseDao具体是做什么操作的?

三、BaseDao封装增删改查(代码详解)

1)基础的JDBC操作类

2)BaseDao封装增删改查

3)演示BaseDao增删改查使用方


一、什么是BaseDao?

BaseDao是一种通用的数据访问对象,用于提供对数据库的基本操作,例如插入、更新、删除和查询数据等。它通常封装了对数据库的底层操作,使得其他DAO对象可以继承BaseDao以获得对数据库的访问能力,同时减少了重复的代码编写。BaseDao可以提供基本的CRUD(创建、读取、更新、删除)功能,同时也可以实现一些通用的查询方法,例如按条件查询、分页查询等。通过使用BaseDao,开发人员可以更加方便地操作数据库,提高开发效率。

BaseDao的优点:

1、代码复用

BaseDao提供了通用的数据库操作方法,可以将一些重复的数据库操作封装起来,从而减少代码冗余。

2、统一管理

通过BaseDao可以将数据库操作集中管理,可以统一维护和修改数据库操作逻辑,提高代码的可维护性。

3、提高开发效率

使用BaseDao可以快速完成数据库操作,减少开发人员编写重复代码的时间,提高开发效率。

4、提供扩展性

BaseDao可以根据具体业务需求进行扩展,例如添加新的查询方法或者自定义的数据库操作逻辑。

5、降低耦合性

通过BaseDao可以将数据库操作与业务逻辑分离,降低模块之间的耦合性,提高系统的可维护性和可测试性。

综上所述,BaseDao的使用可以简化数据库操作,提高开发效率和代码质量。

二、BaseDao具体是做什么操作的?

BaseDao主要负责从数据库获取数据,对数据库中表的增删改查等数据进行操作。

具体来说,BaseDao可以完成以下操作:

1, 新增数据:将数据新增到数据库中,包括单条数据和批量数据新增。

2,修改数据:修改数据库中已有的数据,可以根据指定的条件来修改更新数据。

3,删除数据:删除数据库中的数据,可以根据指定的条件来删除数据。

4,查询数据:从数据库中获取数据,可以根据指定的条件进行查询,也可以进行分页查询。

除了上述基本操作,BaseDao还可以提供一些通用的查询方法,例如按条件查询、排序查询、聚合查询等,以满足各种不同的业务需求。通过继承BaseDao,开发人员可以复用这些基本操作,减少重复的代码编写,提高开发效率。

三、BaseDao封装增删改查(代码详解)

1)基础的JDBC操作类

  • 更新操作 (添加、修改、删除)
      1. 添加(添加单条数据和批量数据)
      1. 修改(修改数据库中已有的数据,可以根据指定的条件来修改更新数据)
      1. 删除(删除数据库中的数据,可以根据指定的条件来删除数据)
  • 查询操作
      1. 查询一个字段 (只会返回一条记录且只有一个字段;常用场景:查询总数量)
      1. 查询集合

2)BaseDao封装增删改查

1、连接:将数据库与Java进行连接

java 复制代码
/**
 * 数据库连接
 */
public class BaseDao {
    private String driver = "com.mysql.jdbc.Driver";// 数据库驱动字符串
    private String url = "jdbc:mysql://localhost:3306/epet";// 连接URL字符串
    private String user = "root"; // 数据库用户名
    private String password = "root"; // 用户密码
    Connection conn = null;				// 数据连接对象
    /**
     * 获取数据库连接对象
     */
    public Connection getConnection() {
        if(conn==null) {
            // 获取连接并捕获异常
            try {
                Class.forName(driver);
                conn = DriverManager.getConnection(url, user, password);
            } catch (Exception e) {
                e.printStackTrace();// 异常处理
            }
        }
        return conn;/ 返回连接对象
    }

2.1、查询:查询一个字段(返回一条记录且只有一个字段,常用场景:查询走数量)

java 复制代码
/**
     * 查看的操作
     * @param sql 预编译的 SQL 语句
     * @param objs 参数的字符串数组
     * @return 返回查看数据行数
     *查询一个字段 (只会返回一条记录且只有一个字段;常用场景:查询总数量)
     * 1、得到数据库连接
     * 2、定义sql语句
     * 3、预编译
     * 4、如果有参数,则设置参数,下标从1开始 (数组或集合、循环设置参数)
     * 5、执行查询,返回结果集
     * 6、判断并分析结果集
     * 7、关闭资源
     */
    public ResultSet getCheckAll(String sql,Object [] objs){
        ResultSet rs=null;
        PreparedStatement pstmt = null;
        try {
            //得到数据库连接
            getConnection();
            //定义sql语句
            pstmt=conn.prepareStatement(sql);
            //预编译
            if(objs!=null){
                //如果有参数,则设置参数,下标从1开始 (数组或集合、循环设置参数)
                for (int i = 0; i <objs.length; i++) {
                    pstmt.setObject(i+1, objs[i]);
                }
            }
            //执行查询,返回结果集
            rs=pstmt.executeQuery();
        } catch (SQLException e) {
            //抛出异常
            e.printStackTrace();
        } finally{
            //关闭资源
            closeAll(conn,pstmt,rs);
        }
        return rs;
    }

3、增删改:增、删、改一个字段(返回一条记录是否更新成功!)

java 复制代码
/**
     * 增、删、改的操作
     * @param preparedSql 预编译的 SQL 语句
     * @param param 参数的字符串数组
     * @return 影响的行数
     * 增、删、改一个字段(返回一条记录是否更新成功!)
     * 1、得到数据库连接
     * 2、定义sql语句
     * 3、预编译
     * 4、如果有参数,则设置参数,下标从1开始 (数组或集合、循环设置参数)
     * 5、执行增、删、改,返回结果
     * 6、判断并分析结果
     * 7、关闭资源
     */
    public int exceuteUpdate (String preparedSql, Object[] param) {
        PreparedStatement pstmt = null;
        int num = 0;
        //得到数据库连接
        conn =  getConnection();
        try {
            //定义sql语句
            pstmt = conn.prepareStatement(preparedSql);
            if (param != null) {
                for (int i = 0; i < param.length; i++) {
                    //为预编译sql设置参数
                    pstmt.setObject(i + 1, param[i]);
                }
            }
            //执行增、删、改,返回结果
            num = pstmt.executeUpdate();
        } catch (SQLException e) {
            //抛出sql类型异常
            e.printStackTrace();
        } finally{
            //关闭资源
            closeAll(conn,pstmt,null);
        }
        return num;
    }

4、关闭:判断结果集对象是否为空,是则关闭

java 复制代码
/**
     * 关闭数据库连接
     * @param conn 数据库连接
     * @param stmt Statement对象
     * @param rs 结果集
     */
    public void closeAll(Connection conn, Statement stmt, ResultSet rs) {
        // 若结果集对象不为空,则关闭
        if (rs != null) {
            try {
                rs.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        // 若Statement对象不为空,则关闭
        if (stmt != null) {
            try {
                stmt.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        // 若数据库连接对象不为空,则关闭
        if (conn != null) {
            try {
                conn.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

3)演示BaseDao增删改查使用方法

以下代码是进行测试BaseDao增删改查以及演示BaseDao增删改查使用方法

java 复制代码
package cn.gd.dao;
/**
 * 测试BaseDao增删改查
 * 演示BaseDao增删改查使用方法
 * */
public class testDao {
    public static void main(String[] args) {
        /*导入BaseDao方法*/
        BaseDao dao = new BaseDao();

        /*1、测试新增功能*/
        //1.1、传入sql语句 1.2、传入Object类型对象
        String sqlAdd = "insert into booksTab(id,name,author,price)VALUES(?,?,?,?)";
        Object[] objsAdd = {1001, "java入门到入狱", "唐某某",158};
        //返回结果
        dao.exceuteUpdate(sqlAdd, objsAdd);

        /*2、测试删除功能*/
        //2.1、传入sql语句 2.2、传入Object类型对象
        String sqlDel = "delete booksTab where id = ?";
        Object[] objsDel = {1001};
        //返回结果
        dao.exceuteUpdate(sqlDel, objsDel);

        /*3、测试修改功能*/
        //3.1、传入sql语句 3.2、传入Object类型对象
        String sqlUpdate = "update booksTab set name= ?,author = ?,price =? where id = ?";
        Object[] objsUpdate = {"java入门到入狱","唐某某",158,1001};
        //返回结果
        dao.exceuteUpdate(sqlUpdate, objsUpdate);

        /*4、测试查看功能*/
        //4.1、传入sql语句 4.2、传入Object类型对象
        String sqlCheck = "select * from booksTab;";
        Object[] objsCheck = {};
        //返回结果集
        dao.getCheckAll(sqlCheck, objsCheck);
    }
}

总结不易,希望宝宝们不要吝啬亲爱的👍哟(^U^)ノ~YO! 如有问题,欢迎评论区批评指正😁

相关推荐
Elastic 中国社区官方博客5 小时前
在 Elasticsearch 中使用 Mistral Chat completions 进行上下文工程
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
编程爱好者熊浪6 小时前
两次连接池泄露的BUG
java·数据库
TDengine (老段)8 小时前
TDengine 字符串函数 CHAR 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
qq7422349848 小时前
Python操作数据库之pyodbc
开发语言·数据库·python
姚远Oracle ACE8 小时前
Oracle 如何计算 AWR 报告中的 Sessions 数量
数据库·oracle
Dxy12393102169 小时前
MySQL的SUBSTRING函数详解与应用
数据库·mysql
码力引擎9 小时前
【零基础学MySQL】第十二章:DCL详解
数据库·mysql·1024程序员节
杨云龙UP9 小时前
【MySQL迁移】MySQL数据库迁移实战(利用mysqldump从Windows 5.7迁至Linux 8.0)
linux·运维·数据库·mysql·mssql
l1t9 小时前
利用DeepSeek辅助修改luadbi-duckdb读取DuckDB decimal数据类型
c语言·数据库·单元测试·lua·duckdb
安当加密9 小时前
Nacos配置安全治理:把数据库密码从YAML里请出去
数据库·安全