方法一:要三次以上的积分,那么肯定要查找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