第一阶段的课程已经结束了,技术是学到了一些,但是大家学的都一样,这些技术是都知道的,而且有不少同学比我学的好啊,感觉也没什么好分享的。
我学完mysql的时候,一个比我早出来工作的朋友问我一个小问题,就是如何查找成绩都及格的人的人数。我当时就跟他说” SELECT * FROM 你的表 WHERE 第一科成绩>=60 AND 第二科成绩>=60;就这样”。然后他说不对,科目是未知的。然后我就按照他的意思试着建了一个新的表格,这就是当时用的表格,表名test:
1.png (12.82 KB, 下载次数: 0)
2017-12-4 16:46 上传
然后用” SELECT * FROM test WHERE score>60;”查找出及格的成绩的人的信息。
2.png (7.23 KB, 下载次数: 0)
2017-12-4 16:46 上传
感觉不能进行操作了。那我就反着查找用” SELECT * FROM testWHERE score<60;”查出成绩不及格的人的信息。
3.png (7.55 KB, 下载次数: 0)
2017-12-4 16:46 上传
感觉还是没法操作。突然发现,查找出来的数据都是表格,那我是不是能对查找出来的数据进行二次查找?我试着使用”SELECT NAME FROM(SELECT NAME FROM test WHERE score>60;)WHERENAME NOT IN (SELECT NAME FROM test WHERE score<60;);”然后就报错了,大概意思就是我这个语句有问题。我发现我根本不用在成绩及格的人里面查找不及格的人。然后我就换成了”SELECT NAME FROM test WHERE NAME NOT IN (SELECT NAME FROM testWHERE score<60;);”然后还是报错了,说我右括号有问题。
4.png (28.01 KB, 下载次数: 0)
2017-12-4 16:47 上传
这个不用括号明显不对吧,我就试着去掉一个分号” SELECT NAME FROMtest WHERE NAME NOT IN(SELECT NAME FROM test WHERE score<60);”结果还真能用:
5.png (4.78 KB, 下载次数: 0)
2017-12-4 16:47 上传
虽然查到的名字重复了,不过还是做出来的。