mysql中一个字段同时满足多个条件,(3个以上)

mysql中一个字段同时满足多个条件,(3个以上),第1张

SELECT

t.file_id

FROM

app_polly_file_labels t

WHERE

t.style = '清新'

or t.style = '甜美'

or t.style = '韩潮来袭'

GROUP BY t.file_id

HAVING count(t.file_id)=3

或者

SELECT

a.file_id

FROM

app_polly_file_labels a

INNER JOIN app_polly_file_labels b ON a.file_id = b.file_id

INNER JOIN app_polly_file_labels c  ON a.file_id = c.file_id

WHERE

a.style ='清新'

AND b.style ='甜美'

AND c.style ='韩潮来袭'

扩展资料:

sql常用的复杂查询语句

一、选择指定的列

select Sno as 学号,Sname as 姓名 from student

select Sno,Sname from student

二、查询全部列

select * from student

三、对查询后的指定列进行命名

select Sname as 姓名,(2014-Sage) as 出生年 from student

select Sname ,(2014-Sage) from student

四、消除取值重复的行

select distinct Sno as 选修了课程的学生学号 from SC

select distinct Sno from SC

五、选择表中若干元组,满足条件

select Sname as 学生姓名 from student where Sdept='IS'

参考链接:SQL语句大全

CASE WHEN是列出几个并行的条件,几个情况都是并列的,优先级从前往后。

所以如果你的情况条件从小到大,那么遇到前边的,虽然可能符合多个条件,但是优先级是前边的优于后边的。所以遇到第一个符合的,就会取出这个条件需要的数据,而不会再往后判断。

case case_value

when when_value then statement_list

[when when_value then statement_list]…

[else statement_list]

end case

case_value:参数表示条件判断的变量;

when_value:参数表示变量的取值;

statement_list:参数表示不同when_value值的执行语句。

case语句的另一种形式。语法2:

case

when search_condition then statement_list

[when search_condition then statement_list]…

[else statement_list]

end case。

要求查找到学校不同年级中每个年级的最高分人员信息,并列第一的学生信息都要查询出来

首先准备数据

分析:可以使用group by 对班级进行分组,再使用max函数找出每个年级的最高分数,所以可以这样写

执行上面的语句可以得到如下结果

可以看出这样已经查询出每个年级对应的最高分,那根据这2个条件,再去表里查询对应年级和分数的学生信息即可

这样执行出来的结果就可以找到每个年级最高分的学生信息,同时并列第一的学生也可以查询到,结果如下

注意:查询列中的字段如果不是group by的字段,那么需要对该字段使用聚合函数,所以这里使用max()找出最大值,而student字段是没法使用的,否则查询出来的就是多个,所以需要使用子查询


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8613777.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-18
下一篇 2023-04-18

发表评论

登录后才能评论

评论列表(0条)

保存