RxJava+SpringBoot使用場景:統(tǒng)計(jì)語數(shù)英及格的人數(shù)

需求描述

統(tǒng)計(jì)語數(shù)英及格的人數(shù)

  • 數(shù)據(jù)庫設(shè)計(jì)
    select * from grade;
grade_id student_id grade_course grade_num
1 1 語文 1
2 1 數(shù)學(xué) 85
3 1 英語 83
4 2 語文 16
5 2 數(shù)學(xué) 21
6 2 英語 14
7 3 語文 59
8 3 數(shù)學(xué) 52
9 3 英語 9
10 4 語文 36
11 4 數(shù)學(xué) 46
12 4 英語 26

代碼處理

controller

  • 傳統(tǒng)curd方案
   @GetMapping("/passedCount")
    public Map<String, Long> passedCount(){
        return gradeRxService.studnetPassedCount();
    }
  • RxJava方案
    // controller
    @GetMapping(value = "/passedCountObservable")
    public Flowable passedCountObservable(){
        return gradeRxService.passedCountObservable();
    }
// 返回的Flowable還需要解析成對(duì)應(yīng)的對(duì)象才能返回給前端
@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層

-- 傳統(tǒng)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());
            /* 打印結(jié)果
            *英語Thread[RxCachedThreadScheduler-3,5,main]
            *語文Thread[RxCachedThreadScheduler-2,5,main]
            *數(shù)學(xué)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>

實(shí)現(xiàn)效果

  • 傳統(tǒng)curd方案


    image.png
  • RxJava方案


    image.png

代碼分析

  • 數(shù)據(jù)持久層處理方式不變
  • 邏輯service層如果通過多次查詢合并返回給前端的情況下適用Flowable來進(jìn)行并發(fā)提高響應(yīng)速度。
  • controller層對(duì)返回的Flowable/abservable要做層解析然后返回給前端
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容