package com.doumee.service.business.impl; import com.doumee.service.business.third.model.PageData; import com.doumee.service.business.third.model.PageWrap; import com.doumee.core.utils.Constants; import com.doumee.dao.business.ParksMapper; import com.doumee.dao.business.join.ParksJoinMapper; import com.doumee.dao.business.model.Parks; import com.doumee.service.business.ParksService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.github.yulichang.wrapper.MPJLambdaWrapper; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.List; import java.util.Objects; /** * 停车库信息表Service实现 * @author 江蹄蹄 * @date 2023/11/30 15:33 */ @Service public class ParksServiceImpl implements ParksService { @Autowired private ParksMapper parksMapper; @Autowired private ParksJoinMapper parksJoinMapper; @Override public Integer create(Parks parks) { parksMapper.insert(parks); return parks.getId(); } @Override public void deleteById(Integer id) { parksMapper.deleteById(id); } @Override public void delete(Parks parks) { UpdateWrapper deleteWrapper = new UpdateWrapper<>(parks); parksMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } parksMapper.deleteBatchIds(ids); } @Override public void updateById(Parks parks) { parksMapper.updateById(parks); } @Override public void updateByIdInBatch(List parkss) { if (CollectionUtils.isEmpty(parkss)) { return; } for (Parks parks: parkss) { this.updateById(parks); } } @Override public Parks findById(Integer id) { return parksMapper.selectById(id); } @Override public Parks findOne(Parks parks) { QueryWrapper wrapper = new QueryWrapper<>(parks); return parksMapper.selectOne(wrapper); } @Override public List findList(Parks parks) { MPJLambdaWrapper queryWrapper = new MPJLambdaWrapper<>(); queryWrapper.isNull(Parks::getParentHkId); queryWrapper.eq(Parks::getIsdeleted,Constants.ZERO); queryWrapper.orderByDesc(Parks::getCreateDate); return parksMapper.selectList(queryWrapper); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); MPJLambdaWrapper queryWrapper = new MPJLambdaWrapper<>(); queryWrapper.selectAll(Parks.class); queryWrapper.select(" p.name as parentName"); queryWrapper.leftJoin(" parks p on p.id=t.PARENT_HK_ID"); queryWrapper.eq(Parks::getIsdeleted, Constants.ZERO); queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getName()),Parks::getName,pageWrap.getModel().getName()); queryWrapper.eq(Objects.nonNull(pageWrap.getModel().getParentHkId()),Parks::getParentHkId,pageWrap.getModel().getParentHkId()); queryWrapper.orderByDesc(Parks::getCreateDate); IPage result = parksJoinMapper.selectJoinPage(page, Parks.class,queryWrapper); return PageData.from(result); } @Override public long count(Parks parks) { QueryWrapper wrapper = new QueryWrapper<>(parks); return parksMapper.selectCount(wrapper); } }