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 {
    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 queryMulti(String sql, Class clazz,Object... parameters){
        Connection connection = JdbcByDruid.getConnection();
        try {
                                          //这个参数表示返回一个对象列表
            return qr.query(connection,sql,new BeanListHandler(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 clazz,Object... parameters){
        Connection connection = JdbcByDruid.getConnection();
        try {
                                           //这个参数表示返回一个对象
            return qr.query(connection,sql,new BeanHandler(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语句都不用写了
  • 分页更简单

你可能感兴趣的:(后端框架,Java,mybatis,oracle,数据库)