A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 平方差公式 中级黑马   /  2017-12-4 16:48  /  1342 人查看  /  9 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

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

评分

参与人数 2技术分 +6 黑马币 +8 收起 理由
皖哥哥 + 6 赞一个!
合肥就业部 + 8 赞一个!

查看全部评分

9 个回复

倒序浏览
回复 使用道具 举报
回复 使用道具 举报
回复 使用道具 举报
不错
回复 使用道具 举报
黄桂林 来自手机 初级黑马 2018-5-3 17:59:47
地板
666666666666666
回复 使用道具 举报
回复 使用道具 举报
回复 使用道具 举报
回复 使用道具 举报
骑着小猪看雪 来自手机 黑马粉丝团 2018-5-4 10:22:30
10#
不错
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马