方法一:要三次以上的积分,那么肯定要查找3个id不同但是积分相同的情况,怎么比较一列和另外一列是否相等呢?在一个表里面感觉无法做到,那么最简单就是利用笛卡尔积了,1个表看成3个表,联立三个表number相同的部分
,笛卡尔积如下:

第1个表
第2个表
第3个表
id number id number id number
1 111 1
111 1 111
2
333 2 333 2 333
3
111 3 111 3 111
4
111 4 111 4 111
5 333 5 333 5 333
那么可能就是举例一种情况就是寻找第1个表id为1的111,寻找第2个表id为3的111,寻找第3个表id4为的111,那么就找到一个111,输出111
但是上面这种找法可能会有重复的,比如第1个表id为3的111,寻找第2个表id为1的111,寻找第3个表id4为的111,那么又找到一个111,所以要去重。代码如下:
SELECT  DISTINCT g1.number AS times
FROM
    grade g1,
    grade g2,
    grade g3
WHERE
    g1.id != g2.id
    AND g2.id != g3.id 
    AND g1.id !=g3.id
    AND g1.number = g2.number
    AND g2.number = g3.number
;


方法二:
使用group by 将积分分组,然后用having找到积分的个数大于等于3的:
select number from grade group by number having count(*)>=3