首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

mysql 分组统计 case when 及 if 语句使用

分组:根据地区、类别、中文名称分类; 判断:根据类型进行判断同时要求和 因为中文名称重复的就是1部,所以统计的时候,要使用到distinct去重。... when   t.play_classification = 10  then t.submit_num  else 0 end  ) as  '电视剧集数' , SUM(CASE when   t.play_classification... = 20  then t.submit_num  else 0 end  ) as  '电影集数' , SUM(CASE when   t.play_classification = 30  then... t.submit_num  else 0 end  ) as  '动画片集数', # -- 题材情况 SUM(CASE when t.theme_type = 1  then t.submit_num...', SUM(CASE when t.theme_type = 3  then t.submit_num  else 0 end  ) as '情感偶像', SUM(CASE when t.theme_type

2.4K10

SELECT 使用 FROM 子句

Oracle 23c中提供了一个非常有价值增强功能。没有 FROM 子句的情况下运行 SELECT 表达式查询可以帮助开发人员执行计算、检索系统函数或生成临时结果,而无需引用任何特定的表。...例如,它可以用于以下情况: 计算:开发人员可以直接计算表达式,而无需从表获取数据。例如:SELECT 2 + 3; 将简单地返回 5。...用途:Dual表最常见的用途之一是SQL查询执行一些函数、表达式或检索常量。...例如,您可以使用它来检索系统级函数的结果,比如 SELECT SYSDATE FROM DUAL; 将返回当前日期时间。 数据:Dual表只有一行数据,因此不会存储实际的数据。...Dual表是Oracle数据库中一个小而简单的系统表,主要用于查询执行一些操作或获取值,而不涉及实际的数据检索。

34830

shell脚本case条件语句介绍和使用案例

#前言:这篇我们接着写shell的另外一个条件语句case,上篇讲解了if条件语句。...case条件语句我们常用于实现系统服务启动脚本等场景,case条件语句也相当于if条件语句多分支结构,多个选择,case看起来更规范和易读 #case条件语句的语法格式 case "变量" in...read读取用户输入的数据,然后使用case条件语句进行判断,根据用户输入的值执行相关的操作 #执行效果 [root@shell scripts]# sh num.sh please input a...read读取用户输入的数据,然后使用case条件语句进行判断,根据用户输入的值执行相关的操作,给用户输入的水果添加颜色 #扩展:输出菜单的另外种方式 cat<<-EOF ================...实践3.开发nginx启动脚本 #主要思路: #1.主要通过判断nginx的pid文件有无存在,通过返回值查看有没有运行 #2.通过case语句获取参数进行判断 #3.引入系统函数库functions

5.7K31

一文搞懂select语句MySQL的执行流程!

频繁使用select语句 为了更好地贯穿全文,这里先来列举一个最简单的select查询语句,例如:查询user表id为1001的用户信息,使用下面的SQL语句进行查询。...select * from user where user_id = 1001; 当我们MySQL的命令行输入上述SQL语句时,这条SQL语句到底MySQL是如何执行的呢?...MySQL逻辑架构 介绍select语句MySQL的执行流程之前,我们先来看看MySQL的逻辑架构,因为任何SQL语句的执行都离不开MySQL逻辑架构的支撑。...比如,我们的select语句中如果使用了多个索引,则优化器会决定使用哪个索引来查询数据;再比如,select语句中,有多表关联的操作,优化器会决定各表的连接顺序,数据表的连接顺序不同,对于执行的效率会大不相同...如果开启了慢查询的话,执行select语句时,会在慢查询日志输出一个rows_examined字段,这个字段表示select语句执行的过程扫描了数据表的多少行数据。

3.8K20

SQL-GROUP BY语句MySQL的一个错误使用被兼容的情况

执行语句如下: SELECT * FROM stud GROUP BY saddress; 显示了如下错误: ERROR 1055 (42000): Expression #1 of SELECT list...SQL的grop by 语法为, select 选取分组的列+聚合函数 from 表名称 group by 分组的列 从语法格式来看,是先有分组,再确定检索的列,检索的列只能在参加分组的列中选...即 以下语句都是正确的: select a,b,c from table_name group by a,b,c,d; select a,b from table_name group by a,b,c...; select a,max(a) from table_name group by a,b,c; 以下语句则是错误的: select a,b,c from table_name group by a,...但是DOS是不能的。所以出现了DOS下报错,而在MySQL能够查找的情况(其实这个查找的结果是不对的)。

2K20

MySQLGROUP BY情况下直接使用HAVING语句的问题探究

这篇文章主要介绍了MySQLGROUP BY情况下直接使用HAVING语句的问题探究,同时探究了该情况下MAX与MIN功能的使用情况,需要的朋友可以参考下: 今天有同学给我反应,有一张表,id是主键...旁白 一般来说,HAVING子句是配合GROUP BY使用的,单独使用HAVING本身是不符合规范的, 但是MySQL会做一个重写,加上一个GROUP BY NULL,”SELECT * FROM...t HAVING id=MIN(id)”会被重写为”SELECT * FROM t GROUP BY NULL HAVING id=MIN(id)”,这样语法就符合规范了。...所以啊,”SELECT * FROM t HAVING id=MIN(id)”本质上是”SELECT * FROM t HAVING id=1″, 就能返回一条记录,而”SELECT * FROM t...GROUP BY NULL时MAX/MIN的行为,是这个问题的本质,所以啊,尽量使用标准语法,玩花样SQL之前,一定要搞清楚它的行为是否与理解的一致。

4K41

Golang深入浅出之-Select语句Go并发编程的应用

Go语言的并发编程世界select语句扮演着至关重要的角色,它为Go程序员提供了优雅且高效的通道通信控制机制。...select语句是Go语言特有的语法结构,专门用于协调多个通道(channel)的读写操作。一个select语句中,可以列出多个case,每个case对应一个通道操作(发送或接收)。...常见问题与易错点问题1:忘记初始化通道使用select之前,务必确保所涉及的通道已被正确初始化。...问题2:死锁在并发编程,死锁是一种常见的问题,select语句也不例外。...实践,结合使用context.Context和定时器等工具,可以进一步增强select语句的灵活性与可控性,使您的Go并发代码更加优雅且易于维护。

12310

SQL进阶-1-case使用

本文中记录的是关于case语句的用法 行列转换 已有数据的重分组和分类 与约束的结合使用 针对聚合结果的条件分支 ?...在有些数据库是不支持这种写法,但是mysql是可以顺利执行的: 先对select子句里面的列表进行扫描 再对列进行计算 不推荐使用!!!!!...else 1 end = 1 ) 逻辑与蕴含式 蕴含式,要想P--->Q为真,需要PQ同时为真,或者P为假,或者P的真假无法判定 ?...group by std_id; 新手使用having进行分支,熟练之后可以使用select语句进行分支 总结 case表达式可以写在select子句里时,可以写在聚合函数内部,也可以是外部...能够写列名和常量的位置,都可以使用case语句 case表达式可以写在selectgroup by、having、where、order by子句中 case表达式是一种表达式,而不是语句,具有更好的可移植性

69510

【MySQL】执行计划 explain 及 一条select语句MySQL的奇幻之旅

文章目录 示例 解释 一条select语句MySQL的奇幻之旅 示例 explain select * from emp; 解释 列(Column) 含义(Meaning) id The SELECT...type:此列是优化SQL语句时最需要关注的列之一,此列显示了查询使用了何种类型。...index_merge:查询语句使用了俩个以上的索引,常见使用and、or会出现,官方文档将此类型放在ref_or_null之后,但是很多的情况下由于读取索引过多性能有可能还不如range unique_subquery...语句为value IN (SELECT primary_key FROM single_table WHERE some_expr) index_subquery:子查询的返回结果字段组合是一个索引(...:对数据使用一个外部的索引排序 Using index condition:使用了索引下推 一条select语句MySQL的奇幻之旅 注:MySQL8.0起以取消图中第九步(查询缓存)原因:把查询语句作为

1.2K20

利用 SQL 实现数据分组与透视

CASE WHEN分组 CASE WHEN函数用来对数据进行判断和分组,下面的代码我们对score列的值进行判断,score大于90为优秀,score大于80为良好,score大于70为中等, score...#score字段分组 SELECT *, CASE WHEN score>90 THEN '优秀' WHEN score>=80 AND score<90 THEN '良好' WHEN score>=70...多列分组 而对多列数据分组,可以GROUP BY后面跟多个字段,下面这条SQL语句同时根据课程号和学号进行分组,然后以分数和降序排列。...数据透视 SQL想要达到数据透视表的功能,需要GROUP BY与CASE WHEN结合使用,下面这条SQL语句可以计算不同分数段的人数,现用CASE WHEN对不同的分数段进行分类,然后,用GROUP...#score字段分组 SELECT CASE WHEN score>90 THEN '优秀' WHEN score>=80 AND score<90 THEN '良好' WHEN score>=70

2.3K20

Mysql按条件计数的几种方法

方法2:使用嵌套的SELECT 使用嵌套的SELECT也可以达到目的,每个SELECT子句中统计一个条件下的数据,然后用一个主SELECT把这些统计数据整合起来。...优缺点 优点就是直观,而且速度也比GROUP BY要快。虽然是3条SELECT语句,看起来比GROUP BY的方案多了2条语句,但是它不涉及到排序,这就节省了很多时间。...缺点可能就是语句稍多,对语句数量有洁癖的同学可能会比较不舒服。 方法3:使用CASE WHEN CASE WHEN语句的功能很强大,可以定义灵活的查询条件,很适合进行分类统计。...100,000行数据上的运行时间:0.02365825 秒 分析 此方法的关键在于 COUNT( CASE WHEN `mother` >24 THEN 1 ELSE NULL END ) 这里的...COUNT和CASE WHEN联合使用,做到了分类计数。

4.4K20
领券