> 백엔드 개발 > PHP 튜토리얼 > 如何用积分快速确定用户所在的等级

如何用积分快速确定用户所在的等级

WBOY
풀어 주다: 2016-06-06 20:33:50
원래의
1290명이 탐색했습니다.

<code>用户表:用户序号、用户等级、用户积分

等级表:等级序号、等级名称、积分下限、积分上线
1、v1、0、60
2、v2、61、180
3、v3、181、270
4、v4、271、1000
</code>
로그인 후 복사
로그인 후 복사

已知积分,如果等级与积分有一定规律,就可以根据算法快速确定用户所在等级;
那么没有规律,那么怎么快速确定等级呢?

回复内容:

<code>用户表:用户序号、用户等级、用户积分

等级表:等级序号、等级名称、积分下限、积分上线
1、v1、0、60
2、v2、61、180
3、v3、181、270
4、v4、271、1000
</code>
로그인 후 복사
로그인 후 복사

已知积分,如果等级与积分有一定规律,就可以根据算法快速确定用户所在等级;
那么没有规律,那么怎么快速确定等级呢?

SQL:

<code>select * from grade where low = 222;
</code>
로그인 후 복사

这不就是有序表插入嘛。最简单的做法是二分查找就行了。

如果储存在了数据库的话就直接用sql就可以解决啦,不然的话就想楼上说的用二分呗,找到所有等级的中间等级的积分上限,如果用户积分大于这个上线的话就递归查找比这个等级大的等级,否则就递归查找比这个中间等级小的等级。。。

建议直接在数据库维护储存用户登记信息,不然使用简单的范围查询SQL可能导致你的索引失效。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿