Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 | 29 |
30 | 31 |
Tags
- equals
- HTTP프로토콜
- java enum
- 동기비동기블로킹논블로킹
- 왜불변객체인가
- 공유기작동방식
- 옵티마저
- 검증 실패 예외처리
- biblecash
- 디스패처서블릿
- 래퍼클래스
- rest api
- httpservlet기술
- multipart바인딩
- fcm성능비교
- fcmv1
- 스프링요청반응
- 클라이언트요청반응
- 데이터베이스파서
- fcm데이터구조
- 옵티마이저
- 동등성동일성
- 불변객체
- DispatcherServlet
- multiparfile데이터
- rest api 검증
- 프로세스 생성
- 중첩클래스
- HttpServlet
- Wrapper class
Archives
- Today
- Total
개발은 아름다워
[ biblecash ] 스케쥴러 코드 변경 본문
@Slf4j
@Service
@RequiredArgsConstructor
public class RangeScheduler {
private final RangeRepository rangeRepository;
private final ContentRepository contentRepository;
private final int EVERY_READ_CHAPTER = 5;
//@Scheduled(cron = "0 0 0 * * MON-FRI") // 평일(월~금) 자정에 실행됨
@Scheduled(fixedRate = 1000) // 10초마다 실행
public void updateFiveChapter(){
// 가장 최근 등록된 range를 가져온다
Range recentRage = rangeRepository.findMaxIdxRange();
// 등록된 범위가 없을 경우 바로 최초 등록
if(recentRage == null){
Range range = Range.create( 1, 0, LocalDate.now());
rangeRepository.save(range);
} else {
// 최근 등록된
int recentBook = recentRage.getBook();
int recentEndChapter = recentRage.getEndChapter();
log.info("recentBook : {},recentEndChapter : {}",recentBook,recentEndChapter);
List<Map<String, Integer>> results = contentRepository.findNextChapters(recentBook, recentEndChapter);
for (Map<String, Integer> chapter : results) {
Integer book = chapter.get("book");
Integer chapterNumber = chapter.get("chapter");
System.out.println("Book: " + book + ", Chapter: " + chapterNumber);
}
Map<String,Integer> lastResult = results.get(results.size() - 1);
int book = lastResult.get("book");
int chapter = lastResult.get("chapter");
log.info("book: {},chapter:{}",book,chapter);
Range range = Range.create(book, chapter, LocalDate.now());
rangeRepository.save(range);
}
}
}
public interface RangeRepository extends JpaRepository<Range,Long> {
Optional<Range> findByUpdatedAt(LocalDate dateTime);
@Query(value = "SELECT * FROM range ORDER BY idx DESC LIMIT 1", nativeQuery = true)
Range findMaxIdxRange();
}
@Repository
public interface ContentRepository extends JpaRepository<Content,Long> {
List<Content> findByIdxBetween(int startIdx, int endIdx);
@Query(value = "SELECT COUNT(DISTINCT chapter) " +
"FROM content " +
"WHERE book = :book",
nativeQuery = true)
int countUniqueChaptersByBook(@Param("book") int book);
@Query(value = "SELECT DISTINCT book, chapter " +
"FROM content " +
"WHERE (book > :recentBook) OR (book = :recentBook AND chapter > :recentEndChapter) " +
"ORDER BY book, chapter " +
"LIMIT 5", nativeQuery = true)
List<Map<String,Integer>> findNextChapters(@Param("recentBook") int recentBook,
@Param("recentEndChapter") int recentEndChapter);
}
'프로젝트' 카테고리의 다른 글
[ bible Cash ] 로그인 시, 아이디 존재하지 않는 경우 처리, 추가로 읽은 말씀 기능 (1) | 2025.02.04 |
---|---|
[ bible Cash ] 개인 랭킹, 그룹별 랭킹, 더 읽은 말씀 기능 추가 (0) | 2025.02.04 |
[ bible cash ] 각 계층별 코드 (1) | 2025.01.17 |
[ bible cash ] content, home,signup 페이지 추가,반응형 css 추가,달력 js 추가 (0) | 2025.01.14 |
[ bible cash] thymLeaf 초기 화면 코드 (0) | 2025.01.13 |