MyBatisPlus的通用查询,简直可以丢弃Dao和mapper.xml了

/**
 *
 * @author shenjing
 * @date 2018/6/20
 */
@Service
public class LocalDispatchServiceImpl extends ServiceImpl<Rep_DisPatchDao, Rep_DisPatch> implements LocalDispatchService {
    /**
     * 根据domain组合各种类型的查询,一般的查询就可以通过这个完成了,dao完全没有存在的意义了
     *
     * @param domain
     * @return
     */
    @Override
    public Rep_DisPatch findOneByDomain(Rep_DisPatch domain) {
        EntityWrapper<Rep_DisPatch> eWrapper = new EntityWrapper<>(domain);
        return selectOne(eWrapper);
    }

    /**
     * 根据分页参数进行查询
     *
     * @param dispatchPageParam
     * @return
     */
    @Override
    public Page<Rep_DisPatch> findListByPage(DispatchPageParam dispatchPageParam) {
        Page<Rep_DisPatch> page = new Page<>(dispatchPageParam.getPageIndex(), dispatchPageParam.getPageSize());
        EntityWrapper<Rep_DisPatch> eWrapper = new EntityWrapper<>(dispatchPageParam.getObj());
        Page<Rep_DisPatch> ret = selectPage(page, eWrapper);
        return ret;
    }

}

  此处ServiceImpl,是myBatisPlus提供的一个基类。

DispatchPageParam 是自己写的一个查询参数的封装

/**
 * 基础分页参数
 * @author shenjing
 * @date 2018/6/20
 */
public class BasePageParam<T> {
    T obj;

    int pageIndex;

    int pageSize;

    public T getObj() {
        return obj;
    }

    public void setObj(T obj) {
        this.obj = obj;
    }

    public int getPageIndex() {
        return pageIndex;
    }

    public void setPageIndex(int pageIndex) {
        this.pageIndex = pageIndex;
    }

    public int getPageSize() {
        return pageSize;
    }

    public void setPageSize(int pageSize) {
        this.pageSize = pageSize;
    }
}

  实际上这个里面什么都没有,只要继承基类就可以了

/**
 * Created by shenjing on 2018/6/20.
 */
public class DispatchPageParam extends BasePageParam<Rep_DisPatch> {

}

  

转载于:https://www.cnblogs.com/JangoJing/p/9205405.html

### 回答1: mapper.javamapper.xmlMyBatis框架中的两个重要文件。 mapper.java是一个Java接口,用于定义数据库操作的方法。在mapper.java中,我们可以定义增删改查等操作的方法,并且可以通过注解或XML文件来映射SQL语句。 mapper.xml是一个XML文件,用于定义SQL语句和参数映射。在mapper.xml中,我们可以定义SQL语句,以及SQL语句中的参数和返回值的映射关系。同时,我们也可以在mapper.xml中定义一些复杂的SQL语句,如多表查询、分页查询等。 在MyBatis框架中,mapper.javamapper.xml是一一对应的,即每个mapper.java对应一个mapper.xml文件。这种设计可以使代码更加清晰,易于维护。 ### 回答2: mapper.javamapper.xml都是MyBatis框架中的重要组成部分。其中mapper.javaMyBatis框架中定义DAO的接口,而mapper.xmlDAO接口的具体实现。 mapper.javaDAO的接口,定义了基本的业务操作方法,例如查询、插入、更新、删除等。它主要由两部分组成:一是声明DAO接口的名称和方法,二是声明DAO接口方法的参数和返回值类型。 mapper.xml则是为DAO接口提供具体的实现。mapper.xml中定义了SQL语句,用于访问数据库。它包含SQL语句、参数映射、结果映射等信息。在MyBatis中,mapper.xml文件中的SQL语句是可以动态生成的,这使得MyBatis易于开发。 映射器的使用可以实现业务逻辑与数据访问之间的解耦。它们提供了一个清晰的接口,使开发人员能够快速实现数据访问逻辑。在使用MyBatis框架时,mapper.javamapper.xml通常是组合起来使用的,其中mapper.java提供的接口方法将会调用mapper.xml中定义的SQL语句来实现具体业务逻辑。这种实现方式非常灵活,并且易于维护。 ### 回答3: Mapper.javaMapper.xmlMyBatis框架描述SQL语句和Java类之间映射关系的两种方式。 Mapper.java是使用Java代码来描述SQL语句和对应的参数、返回值类型。Mapper.java中的方法对应SQL语句,参数是该语句需要传递的参数,返回值是SQL语句执行结果。Mapper.java可以使得编写Java程序更加直观,同时也可以静态类型检查,减少代码错误。 Mapper.xml则是使用XML文件来描述SQL语句和Java类之间的映射关系。Mapper.xml中包含了SQL语句、参数类型、返回值类型等信息,而且还可以使用一些特殊标签来处理SQL语句的动态条件、循环等逻辑。Mapper.xml可以使得SQL语句的编写更加灵活,而且可以方便地对SQL语句进行管理和调试。 在实际使用中,通常建议使用Mapper.xml描述复杂的SQL语句逻辑,而使用Mapper.java来描述简单的SQL语句。同时,Mapper.javaMapper.xml并不是互斥的,可以同时使用,也可以根据具体情况只使用其中一种。无论是使用Mapper.java还是Mapper.xml,都可以通过MyBatis框架来解析映射描述文件,并根据映射关系来执行SQL语句。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值