Mybatis-plus使用wrapper多表內(nèi)連接左連接查詢方式
一、先放成功的方法
jar包:mybatis-plus-extenaion-3.4.0
<!--引入MyBatisPlus依賴-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.0</version>
</dependency>1.DAO層,使用注解方式
用inner join [表名] on [條件]關(guān)聯(lián)多表,用${ew.customSqlSegment}表示wrapper的where條件
public interface WReqMstMapper extends BaseMapper<WReqMst>{
@Select("SELECT mst.*,wh1.whname as REQWHNAME,wh2.whname as BYREQWHNAME ,comp.companyname as DEPTNAME FROM w_req_mst mst inner join gen_company comp on mst.deptid=comp.companyid left join gen_wh_def wh1 on mst.reqwhid=wh1.whid inner join gen_wh_def wh2 on mst.byreqwhid=wh2.whid ${ew.customSqlSegment}")
IPage<WReqMst> mlist(IPage<WReqMst> page,@Param(Constants.WRAPPER)Wrapper<WReqMst>wrapper);
}2.Service層
public interface IWReqMstService extends IService<WReqMst> {
IPage<WReqMst> getPageList(WReqMstListDto pageListDto);
}這里可以不用lambda(),可以直接new QueryWrapper<>()來添加條件。
@Service
public class WReqMstServiceImpl extends BaseService<WReqMstMapper, WReqMst> implements IWReqMstService {
private IWReqDtlService wReqDtlService;
@Resource
private WReqMstMapper getWReqMstMapper;
@Override
public IPage<WReqMst> getPageList(WReqMstListDto pageListDto) {
Wrapper<WReqMst> wrapper = Wrappers.<WReqMst>query().lambda()
.like(!StringUtil.isEmpty(pageListDto.getHISREQNO()), WReqMst::getHisreqno, pageListDto.getHISREQNO())
.ge(!StringUtil.isEmpty(pageListDto.getINPUTDATE_Start()), WReqMst::getInputdate, DateTimeUtil.minForTime(pageListDto.getINPUTDATE_Start(), "datetime"))
.le(!StringUtil.isEmpty(pageListDto.getINPUTDATE_End()), WReqMst::getInputdate, DateTimeUtil.maxForTime(pageListDto.getINPUTDATE_End(), "datetime"))
.eq(!StringUtil.isEmpty(pageListDto.getREQTYPE()), WReqMst::getReqtype, pageListDto.getREQTYPE());
return getWReqMstMapper.mlist(ConventPage.getPage(pageListDto), wrapper);//this.page(ConventPage.getPage(pageListDto), wrapper);
}
}3.controller層
@GetMappin
public Response<PageOutput<WReqMstListVo>> getPageList(WReqMstListDto listDto) {
IPage<WReqMst> page = wReqMstService.getPageList(listDto);
List<WReqMstListVo> records = BeanUtil.copyList(page.getRecords(), WReqMstListVo.class);//分頁。wrapper自帶
return Response.ok(ConventPage.getPageOutput(page.getTotal(), records));
}二、未解決
如果不用注解方式,查列表數(shù)據(jù)和有條件的查數(shù)據(jù)我沒法同時存在,我不知道如何同時實現(xiàn)。
先用association進行了一對一表連接,其他代碼和上面一樣。但是xml文件按方法只能無條件查詢,wrapper加上的條件沒有進入xml文件。。。
如果在下面的<select>中加上${ew.customSqlSegment},則可以有條件的查詢,但是沒有使用wrapper添加條件,則結(jié)果為空。
是不是要加上<if test=".....">${ew.customSqlSegment}</if>?
<resultMap id="wReqMstResultMap" type="WReqMst">
<id column="REQMSTID" property="reqmstid"/>
<result column="INPUTDATE" property="inputdate"/>
<result column="DEPTID" property="deptid"/>
<result column="REQWHID" property="reqwhid"/>
<result column="BYREQWHID" property="byreqwhid"/>
<result column="MEMO" property="memo"/>
<association property="deptname" column="DEPTID" select="com.xjrsoft.module.customerTwo.AppManage.genCompany.mapper.GenCompanyMapper.selectNameById"/>
<association property="reqwhname" column="REQWHID" select="com.xjrsoft.module.customerTwo.AppManage.genWh.mapper.GenWhDefMapper.selectNameById"/>
<association property="byreqwhname" column="BYREQWHID" select="com.xjrsoft.module.customerTwo.AppManage.genWh.mapper.GenWhDefMapper.selectNameById"/>
</resultMap>
<select id="wReqMstList" resultMap="wReqMstResultMap">
select *
from w_req_mst
</select>總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
java環(huán)境變量path和classpath的配置
詳解Java Callable接口實現(xiàn)多線程的方式
基于SpringBoot與AES實現(xiàn)接口響應數(shù)據(jù)加密的代碼示例

