RxJava+SpringBoot使用场景:统计语数英及格的人数

https://www.jianshu.com/p/31454fd4f7e8

需求描述

统计语数英及格的人数

  • 数据库设计
    select * from grade;
grade_idstudent_idgrade_coursegrade_num
11语文1
21数学85
31英语83
42语文16
52数学21
62英语14
73语文59
83数学52
93英语9
104语文36
114数学46
124英语26

代码处理

controller

  • 传统curd方案
   @GetMapping("/passedCount")
    public Map<String, Long> passedCount(){
        return gradeRxService.studnetPassedCount();
    }
  • RxJava方案
    // controller
    @GetMapping(value = "/passedCountObservable")
    public Flowable passedCountObservable(){
        return gradeRxService.passedCountObservable();
    }
// 返回的Flowable还需要解析成对应的对象才能返回给前端
@Configuration
@ComponentScan(basePackages = { "com.muyf.alibaba.curd.*" })
public class WebConfig extends WebMvcConfigurerAdapter {
    @Override
    public void addReturnValueHandlers(List<HandlerMethodReturnValueHandler> returnValueHandlers) {
        returnValueHandlers.add(new ObservableReturnValueHandler());
        returnValueHandlers.add(new FlowableReturnValueHandler());
    }
}
public class FlowableReturnValueHandler implements AsyncHandlerMethodReturnValueHandler {
    @Override
    public boolean isAsyncReturnValue(Object returnValue, MethodParameter returnType) {
        return returnValue != null && supportsReturnType(returnType);
    }

    @Override
    public boolean supportsReturnType(MethodParameter returnType) {
        return Observable.class.isAssignableFrom(returnType.getParameterType());
    }

    @Override
    public void handleReturnValue(Object returnValue, MethodParameter returnType, ModelAndViewContainer mavContainer,
                                  NativeWebRequest webRequest) throws Exception {

        if (returnValue == null || !Flowable.class.isInstance(returnValue))  {
            mavContainer.setRequestHandled(true);
            return;
        }

        final Flowable<?> flowable = Flowable.class.cast(returnValue);
        WebAsyncUtils.getAsyncManager(webRequest)
                .startDeferredResultProcessing(new FlowableAdapter<>(flowable), mavContainer);
    }

    private static class FlowableAdapter<T> extends DeferredResult<T> {
        public FlowableAdapter(Flowable<T> flowable) {
            flowable.subscribe(this::setResult, this::setErrorResult);
        }
    }
}

service层

-- 传统curd方案

   @Override
    public Map<String, Long> studnetPassedCount() {
        Map<String,Long> result = new ConcurrentHashMap<>();
        for (String courseName : CourseEnum.courseArray) {
            List<Grade> grades = gradeMapper.selectStudentCountGreatThanGradeNumInCourse(courseName, Long.valueOf(60));
            result.put(courseName,Long.valueOf(grades.size()));
        }
        return result;
    }
  • RxJava方案
    @Override
    public Flowable<GradePassDTO> passedCountObservable() {
        return Flowable.fromArray(CourseEnum.courseArray.toArray()).parallel().runOn(Schedulers.io()).map(course -> {
            System.out.println(course.toString()+Thread.currentThread());
            /* 打印结果
            *英语Thread[RxCachedThreadScheduler-3,5,main]
            *语文Thread[RxCachedThreadScheduler-2,5,main]
            *数学Thread[RxCachedThreadScheduler-4,5,main]
            */
            List<Grade> grades = gradeMapper.selectStudentCountGreatThanGradeNumInCourse(course.toString(), Long.valueOf(60));
            GradePassDTO dto = new GradePassDTO(course.toString(),Long.valueOf(grades.size()));
            return dto;
        }).sequential();
    }

Mapper层

<select id="selectStudentCountGreatThanGradeNumInCourse" resultType="com.muyf.alibaba.curd.domain.grade.Grade">
        select <include refid="Base_Column_List"/> from grade where grade_course = #{courseName} and grade_num > #{gradeNum};
</select>

实现效果

 



作者:木头与琉璃
链接:https://www.jianshu.com/p/31454fd4f7e8
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 传统curd方案

     

    image.png

  • RxJava方案

     

    image.png

    代码分析

  • 数据持久层处理方式不变
  • 逻辑service层如果通过多次查询合并返回给前端的情况下适用Flowable来进行并发提高响应速度。
  • controller层对返回的Flowable/abservable要做层解析然后返回给前端
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值