MBatis-plus:架构使用

(1)简单搭建方式

Mapper

@Mapper
public interface HospitalSetMapper extends BaseMapper<HospitalSet> {
}

Service层接口

public interface HospitalSetService extends IService<HospitalSet> {
}

Service实现类

@Service
public class HospitalSetServiceImpl extends ServiceImpl<HospitalSetMapper, HospitalSet> implements HospitalSetService {
}

注意:原来service调用mappe需要把mapper注入到service,但是我们继承了ServiceImpl,里面已经帮助我们完成了注入,直接使用BaseMapper完成调用

Controller

@RestController
@RequestMapping("/admin/hosp/hospitalSet")
public class HospitalSetController {
    @Autowired
    private HospitalSetService hospitalSetService;
}

在MyBatis-Plus不仅在Mapper中给我们封装了方法,在Service也进行了封装,在写代码是会非常的方便,直接通过controller去掉service中的方法,很方便的实现对数据库的操作

(2)复杂搭建方式

Mapper

public interface AppUserMapper extends BaseMapper<AppUser> {
}

Service层接口

public interface BaseService<T> extends IService<T> {
}

实现类BaseServiceImpl

@Slf4j          继承了ServiceImpl,里面已经帮助我们完成了注入BaseMapper
public class BaseServiceImpl<M extends BaseMapper<T>, T extends Object> extends ServiceImpl<M, T> implements BaseService<T>{                                                               
}

业务层公共接口

public interface IAppUserService extends BaseService<AppUser> {
}

业务层实现类AppUserServiceImpl

@Service        
public class AppUserServiceImpl extends BaseServiceImpl<AppUserMapper, AppUser>          
                                                      implements IAppUserService {
}

Controller

@Slf4j
@Api(tags="App用户")
@RestController
@RequestMapping("/bus/user")
public class AppUserController extends BaseController<AppUser, IAppUserService> {
@Autowired
private IAppUserService appUserService;

}

(3)MyBatis-Plus分页接口代码

Controller接口
@AutoLog(value = "用户管理-分页列表查询")
@ApiOperation(value = "App用户-分页列表查询", notes = "App用户-分页列表查询")
@GetMapping(value = "/list")
public Result queryPageList(AppUserReq appUserReq, @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo,
                            @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) {
    Page<AppUserRes> page = new Page<>(pageNo, pageSize);
    IPage<AppUserRes> pageList = appUserService.queryPageList(page, appUserReq);
    return Result.ok(pageList);
}

Service接口 

public interface IAppUserService extends BaseService<AppUser> {

      IPage<AppUserRes> queryPageList(IPage<AppUserRes> page, AppUserReq appUserReq);
}

实现类:

@Service
public class AppUserServiceImpl extends BaseServiceImpl<AppUserMapper, AppUser> implements IAppUserService {
@Override
public IPage<AppUserRes> queryPageList(IPage<AppUserRes> page, AppUserReq appUserReq) {
    Map<String, Object> reqParam = new HashMap<>();
    reqParam.put("companyName", appUserReq.getCompanyName());
    reqParam.put("userMobile", appUserReq.getPhone());
IPage<AppUserRes> resultList = this.baseMapper.queryPage(page, reqParam);
    return resultList;
}

Mapper接口

public interface AppUserMapper extends BaseMapper<AppUser> {

      IPage<AppUserRes> queryPage(IPage<AppUserRes>  page, @Param(value = "p")          Map<String, Object> reqParam);

}

Mapper.xml:写sql

<selectid="queryPage"parameterType="map" resultType="com.hyit.platform.modules.business.user.vo.AppUserRes">
     select
        id,
        user_name,
        company_name,
        phone user_mobile,
        user_type,
        company_review_type companyReviewType,
        user_level,
        company_name companyName,
        locked,
        signup_time signupTime
      from app_user
    <include refid="whereNewsinfo_plus"/>
</select>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

喵俺第一专栏

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

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

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

打赏作者

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

抵扣说明:

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

余额充值