BasicDao、mybatis、mybatisPLUS的区别

        没学mybatis之前写了一个BasicDao。

package BankSystem.dao;
 
import BankSystem.util.JdbcByDruid;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
 
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
 
/**
 * @author 高垚淼
 * @version 1.0
 */
 
//创建所有Dao的基本操作,使用泛型T减少代码量
    @SuppressWarnings("all")
public class BasicDao<T> {
    private QueryRunner qr = new QueryRunner();;
 
    /**
     * 插入、删除、修改语句的通用操作
     * @param sql   传入sql语句
     * @param parameters    可变参数,设置sql中的?通配符
     */
    public int update(String sql,Object... parameters){
        Connection connection = JdbcByDruid.getConnection();
        try {
            return qr.update(connection,sql,parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }finally {
            JdbcByDruid.close(connection);
        }
    }
 
    /**
     * 查询所有的通用操作
     * @param sql  传入sql语句
     * @param clazz  类的字节码文件对象,反射加载该类
     * @param parameters  可变参数,设置sql中的?通配符
     * @return   返回遍历封装T对象的List集合
     */
    public List<T> queryMulti(String sql, Class<T> clazz,Object... parameters){
        Connection connection = JdbcByDruid.getConnection();
        try {
                                          //这个参数表示返回一个对象列表
            return qr.query(connection,sql,new BeanListHandler<T>(clazz),parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }finally {
            JdbcByDruid.close(connection);
        }
    }
 
    /**
     *
     * @param sql  传入sql语句
     * @param clazz  类的字节码文件对象,反射加载该类
     * @param parameters 变参数,设置sql中的?通配符
     * @return  返回单个对象
     */
    public T querySingle(String sql, Class<T> clazz,Object... parameters){
        Connection connection = JdbcByDruid.getConnection();
        try {
                                           //这个参数表示返回一个对象
            return qr.query(connection,sql,new BeanHandler<T>(clazz),parameters);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }finally {
            JdbcByDruid.close(connection);
        }
    }
}

        BasicDao是一个自定义的类,用于封装一些基本的数据库操作,如插入、删除、修改、查询等。它使用了Apache Commons DbUtils库,以及JdbcByDruid工具类,来简化JDBC的使用。
mybatisPLUS是一个基于mybatis的增强框架,它可以简化mybatis的操作,提供了一些常用的功能,如动态条件查询、分页查询、自动填充、逻辑删除等。
        BasicDao和mybatisPLUS的区别主要有以下几点:

  • BasicDao需要自己编写SQL语句,而mybatisPLUS提供了基本的CRUD功能,连SQL语句都不需要编写。
  • BasicDao需要自己管理连接池和事务,而mybatisPLUS可以通过配置文件或注解来设置数据源和事务管理器。
  • BasicDao需要自己处理结果集和参数映射,而mybatisPLUS可以通过注解或XML来实现对象与数据库的ORM字段关系映射。
  • BasicDao不支持动态SQL和Lambda形式调用,而mybatisPLUS提供了动态条件构造器和ActiveRecord模式,可以更灵活地构建和执行SQL。

        mybatis和mybatisPLUS的区别主要在:

  • mybatisPLUS连sql语句都不用写了
  • 分页更简单
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Gavana.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值