Java高级Day52-BasicDAO

138.BasicDao

基本说明:

  1. DAO:data access object 数据访问对象

  2. 这样的通用类,称为 BasicDao,是专门和数据库交互的,即完成对数据库(表)的crud操作

  3. 在BasicDao 基础上,实现一张表对应一个Dao,更好的完成功能,比如 Customer表

代码实现:

复制代码
public class BasicDao<T> { //泛型指定具体的类型
    private QueryRunner qr = new QueryRunner();
    //开发通用的dml发明合法,针对任意的表
    public int update(String sql, Object... parameters) {
        Connection connection = null;
        try{
            connection = JDBCUtilsByDruid.getConnection();
            int update = qr.update(connection, sql, parameters);
            return update;
        } catch (SQLException e) {
            throw new RuntimeException(e);//将编译异常转成运行异常
        }finally {
            JDBCUtilsByDruid.close(null,null,connection);
        }
    }
    //返回多个对象(即查询的结果是多行的),针对任意表
    public List<T> queryMulti(String sql, Class<T> clazz,Object... parameters) {
        Connection connection = null;
        try{
            connection = JDBCUtilsByDruid.getConnection();
            return qr.query(connection, sql, new BeanListHandler<T>(clazz), parameters);
​
        } catch (SQLException e) {
            throw new RuntimeException(e);//将编译异常转成运行异常
        }finally {
            JDBCUtilsByDruid.close(null,null,connection);
        }
    }
​
    //查询单行结果的通用方法
    public T querySingle(String sql, Class<T> clazz, Object... parameters) {
        Connection connection = null;
        try{
            connection = JDBCUtilsByDruid.getConnection();
            return qr.query(connection, sql, new BeanHandler<T>(clazz), parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);//将编译异常转成运行异常
        }finally {
            JDBCUtilsByDruid.close(null,null,connection);
        }
    }
​
    //查询单行单列的方法,返回单值的方法
    public Object queryScalar(String sql, Object... parameters) {
        Connection connection = null;
        try{
            connection = JDBCUtilsByDruid.getConnection();
            return qr.query(connection, sql, new ScalarHandler<>(), parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);//将编译异常转成运行异常
        }finally {
            JDBCUtilsByDruid.close(null,null,connection);
        }
    }
}

测试ActorDAO 对 actor表的crud操作

复制代码
public void testActorDAO() {
    ActorDAO actorDAO = new ActorDAO();
    //1.查询
    List<Actor> actors = actorDAO.queryMulti("select * from actor where id >= ?",Actor.class, 1);
    System.out.println("===查询结果===");
    for(Actor actor : actors) {
        System.out.println(actor);
    }
    
    //2.查询单行记录
    Actor actor = actorDAO.querySingle("select * from actor where id = ?",Actor.class, 1);
    System.out.println("===查询单行结果===");
    System.out.println(actor);
    }
​
    //3.查询单行单列
    Object o = actorDAO.queryScalar("select name from actor where id = ?",6);
    System.out.println("===查询单行单列值===");
    System.out.println(o)
        
    //4. dml操作 insert,update,delete
    int update = actorDAO.update("insert into actor values(null,?,?,?,?)","张无忌","男","2000-1-1","111");
    System.out.println(update > 0 ? "执行成功" : "执行没有影响表");
}
相关推荐
阿猿收手吧!20 小时前
【C++】引用类型全解析:左值、右值与万能引用
开发语言·c++
「QT(C++)开发工程师」20 小时前
C++ 策略模式
开发语言·c++·策略模式
iFeng的小屋20 小时前
【2026最新当当网爬虫分享】用Python爬取千本日本相关图书,自动分析价格分布!
开发语言·爬虫·python
yugi98783820 小时前
基于MATLAB的一键式EMD、EEMD、CEEMD和SSA信号去噪实现
开发语言·matlab·信号去噪
热爱编程的小刘20 小时前
Lesson05&6 --- C&C++内存管理&模板初阶
开发语言·c++
爬山算法21 小时前
Hibernate(85)如何在持续集成/持续部署(CI/CD)中使用Hibernate?
java·ci/cd·hibernate
菜鸟233号21 小时前
力扣647 回文子串 java实现
java·数据结构·leetcode·动态规划
qq_124987075321 小时前
基于Java Web的城市花园小区维修管理系统的设计与实现(源码+论文+部署+安装)
java·开发语言·前端·spring boot·spring·毕业设计·计算机毕业设计
h7ml21 小时前
查券返利机器人的OCR识别集成:Java Tesseract+OpenCV优化图片验证码的自动解析方案
java·机器人·ocr
野犬寒鸦21 小时前
从零起步学习并发编程 || 第五章:悲观锁与乐观锁的思想与实现及实战应用与问题
java·服务器·数据库·学习·语言模型