>데이터 베이스 >Redis >Redis를 사용하여 순위 기능을 구현하는 방법

Redis를 사용하여 순위 기능을 구현하는 방법

藏色散人
藏色散人앞으로
2020-08-13 11:45:244627검색

Redis Tutorial 칼럼에서는 Redis를 사용하여 순위 기능을 구현하는 방법을 소개하겠습니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

Redis를 사용하여 순위 기능을 구현하는 방법

순위 기능은 매우 일반적인 요구 사항입니다. Redis의 Ordered Set 기능을 사용하여 순위 목록을 구현하는 것은 빠르고 좋은 선택입니다.

"사용자 포인트 목록"과 같은 일반 순위가 효과적입니다. 효율성이 없고 항상 전체 순위를 기준으로 순위가 결정된다면 항상 목록의 최상위에 소수의 기존 사용자가 있을 수 있습니다. 신규 사용자에게는 정말 답답한 일입니다.

우선 '오늘의 포인트 목록'을 살펴보겠습니다. 정렬 규칙은 오늘 사용자가 추가한 새 포인트가 많은 것부터 적습니다.

그리고 사용자가 포인트를 추가하면 그날의 포인트 증가를 기록하는 주문 컬렉션을 운영하게 됩니다.
오늘이 2015년 4월 1일이고 UID 1인 사용자가 특정 작업으로 인해 5점을 얻었다고 가정합니다.
Redis 명령은 다음과 같습니다.

ZINCRBY rank:20150401 5 1

다른 여러 사용자도 포인트를 추가했다고 가정합니다.

ZINCRBY rank:20150401 1 2
ZINCRBY rank:20150401 10 3

현재 정렬된 세트 순위의 데이터를 살펴보세요: 20150401(withscores 매개변수를 사용하여 요소의 점수를 얻을 수 있습니다) ):

ZRANGE rank:20150401 0 -1 withscores
1) "2"
2) "1"
3) "1"
4) "5"
5) "3"
6) "10"

Follow 점수는 높은 것부터 낮은 것 순으로 상위 10개를 얻습니다.

ZREVRANGE rank:20150401 0 9 withscores
1) "3"
2) "10"
3) "1"
4) "5"
5) "2"
6) "1"

요소가 3개뿐이므로 이 데이터를 쿼리했습니다.

매일 그날의 포인트 순위를 기록하면 온갖 트릭이 담긴 다른 목록도 간단해집니다.
예: "어제 순위":

ZREVRANGE rank:20150331 0 9 withscores

합집합을 사용하여 여러 날의 포인트 합을 구현하여 "지난주 순위" 실현:

ZUNIONSTORE rank:last_week 7 rank:20150323 rank:20150324 rank:20150325 rank:20150326 rank:20150327 rank:20150328 rank:20150329 WEIGHTS 1 1 1 1 1 1 1

이렇게 하면 7일간의 포인트 기록이 주문된 세트에 병합됩니다. 순위:지난_주 . 가중치 계수 WEIGHTS 지정하지 않은 경우 기본값은 1입니다. 내용을 숨기지 않기 위해 일부러 적어봤습니다.
그러면 지난 주 순위 상위 10위를 조회하기 위한 정보는

ZREVRANGE rank:last_week  0 9 withscores

"월간 목록", "분기별 목록", "연간 목록" 등입니다.

위 내용은 Redis를 사용하여 순위 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제