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 ? "执行成功" : "执行没有影响表");
}
相关推荐
肩上风骋6 分钟前
C++14特性
开发语言·c++·c++14特性
_日拱一卒17 分钟前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
隔窗听雨眠23 分钟前
Nginx网关响应慢排查手记
java·服务器·nginx
智慧物业老杨1 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
源码宝1 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
JAVA社区2 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展
弥树子2 小时前
踩坑记录:服务器内网调用接口,真实请求URL与官方公开URL不一致问题排查
开发语言·php
金銀銅鐵2 小时前
[Java] 如何理解 class 文件中方法的 descriptor?
java·后端
云烟成雨TD2 小时前
Spring AI Alibaba 1.x 系列【63】AI Agent 长期记忆
java·人工智能·spring
z落落2 小时前
C# ToCharArray + foreach遍历 + String与StringBuilder
开发语言·c#