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 ? "执行成功" : "执行没有影响表");
}
相关推荐
W.A委员会11 分钟前
JS原型链详解
开发语言·javascript·原型模式
止语Lab22 分钟前
Go并发编程实战:Channel 还是 Mutex?一个场景驱动的选择框架
开发语言·后端·golang
她说彩礼65万1 小时前
C# 实现简单的日志打印
开发语言·javascript·c#
绿浪19841 小时前
c# 中结构体 的定义字符串字段(性能优化)
开发语言·c#
HoneyMoose1 小时前
Jenkins Cloudflare 部署提示错误
java·servlet·jenkins
阿丰资源1 小时前
基于SpringBoot的物流信息管理系统设计与实现(附资料)
java·spring boot·后端
Predestination王瀞潞1 小时前
Java EE3-我独自整合(第四章:Spring bean标签的常见配置)
java·spring·java-ee
overmind1 小时前
oeasy Python 121[专业选修]列表_多维列表运算_列表相加_列表相乘
java·windows·python
资深数据库专家1 小时前
总账EBS 应用服务器1 的监控分析
java·网络·数据库
房开民1 小时前
可变参数模板
java·开发语言·算法