当前位置: 首页 > news >正文

政府部门做网站百度集团总部在哪里

政府部门做网站,百度集团总部在哪里,请兼职做企业网站设计怎么收费,整站策划营销型网站建设网站优化过滤顺序指的是mysql的逻辑执行顺序,个人觉得我们可以按照执行顺序来写select查询语句。 目录 一、执行顺序二、小tips三、案例第一轮查询:统计每个num的出现次数第二轮查询:计算**最多次数**第三轮查询:找到所有出现次数为最多次…

过滤顺序指的是mysql的逻辑执行顺序,个人觉得我们可以按照执行顺序来写select查询语句。

目录

  • 一、执行顺序
  • 二、小tips
  • 三、案例
    • 第一轮查询:统计每个num的出现次数
    • 第二轮查询:计算**最多次数**
    • 第三轮查询:找到所有出现次数为最多次数的所有数字,并找到这些数字中的最大值
    • 计算结果展示:
    • 补充说明
  • 四、结语

一、执行顺序

  1. FROM子句
    这是执行的第一步,数据库系统读取指定的表和视图,这是后续所有操作的基础。

  2. JOIN
    如果涉及多个表,则基于JOIN条件,将表中的行组合起来。

  3. WHERE子句:对行的过滤
    接下来,数据库系统会过滤掉不符合WHERE条件的行。这是在聚集函数(如COUNT、SUM等)应用之前进行的,因此只作用于原始数据。
    WHERE 子句后面不能直接接聚合函数(如 COUNT(), MAX(), SUM() 等)。WHERE 子句用于指定从基础数据表中选择哪些行的标准,这些标准必须是能够对每一行单独评估的布尔表达式。由于聚合函数是在行群(group)上操作的,而不是单独的行上,所以它们不能直接在 WHERE 子句中使用。
    总之,是对原始数据的每一行进行操作!!!没法联系多行进行判断,所以不能用聚集函数!!!!!

  4. GROUP BY子句
    将之前得到的结果集按照指定的列值进行分组,为聚集函数(如COUNT、SUM等)的应用做准备。

  5. HAVING子句:对组的过滤
    与WHERE类似,但它是在聚集函数应用后对分组的结果进行过滤,相比于where,涉及到了多行,所以可以使用聚集函数。
    可以简单理解成:where过滤掉行,having过滤掉组,均是接的布尔表达式。
    没有 GROUP BY 的上下文中单独使用 HAVING 是不常见的,而且可能不被所有SQL数据库支持。

  6. SELECT
    选取指定的列。
    如果使用了聚集函数,那么非聚集列必须出现在GROUP BY子句中,除非它们在聚集函数内部。比如使用了select max(num),它将从每一组中找到一个最大的num,而不是整张表中找
    关于增加一列:根据条件显示内容

    casewhen 条件1(布尔表达式) then 满足条件1要展示的结果when 条件2(布尔表达式) then 不满足条件1满足条件2的结果else 都不满足的结果
    end as 别名
    

二、小tips

  1. 子查询作为数据源,必须有别名,如果是在where、having语句中,则不拥有。

  2. 聚集函数嵌套的问题:
    不允许直接嵌套聚合函数:聚合函数(如AVG(), SUM(), MAX()等)通常不允许直接嵌套使用。也就是说,一个聚合函数的结果不能直接成为另一个聚合函数的输入,如MAX(COUNT(column))是不允许的。
    允许聚合结果被其他函数处理:聚合函数的结果可以被其他非聚合函数处理,如ROUND(AVG(column), 2)是允许的。这是因为ROUND函数在这里不是在进行聚合操作,而是在对聚合操作的单一结果值进行格式化或转换。

三、案例

假设目前数据库有一个表nums:

CREATE table nums(num INTEGER
);

插入样本数据:

insert into nums(num)
values(8),(8),(3),(3),(1),(2),(5),(6);

任务:找到nums表中出现次数最多的数字,如有多个,展示最大的结果。

下面开始按照过滤顺序具体实现:
我们将任务拆分为三轮:
第一轮:统计每个num的出现次数
第二轮:计算最多次数
第三轮:找到所有出现次数为最多次数的所有数字,并找到这些数字中的最大值
在每一轮中,将按照执行顺序一步步书写语句:

  1. FROM
  2. JOIN
  3. WHERE
  4. GROUP BY
  5. HAVING
  6. SELECT
  7. DISTINCT
  8. ORDER BY
  9. LIMIT / OFFSET

强调一下,每一步操作都是基于前面执行的结果再操作的,比如where就只会对原始from和join后的结果对行进行过滤,不会对group by的结果做过滤,这一点很重要!!!

第一轮查询:统计每个num的出现次数

  1. FROM:找到表nums
	from nums
  1. JOIN
    不需要涉及多个表,略。
  2. WHERE
    不需要过滤掉任何行,所以略。
  3. GROUP BY
    需要找到每个数字出现的次数,自然需要分组,根据num分组:
	from numsgroup by num
  1. HAVING
    不需要略掉任何组,所以略。
  2. SELECT
    需要得到统计结果:
	select count(num) as frequencyfrom numsgroup by num

这里起一个别名,因为后续查询里,这个数字需要被用到,所以记得取别名
7. DISTINCT

8. ORDER BY

9. LIMIT / OFFSET

第二轮查询:计算最多次数

  1. FROM
    这里需要找到出现次数中的最大值,所以第一轮查询的结果,将作为这一轮查询的数据源。
from(select count(num) as frequencyfrom numsgroup by num) table_temp

根据前面小tips的第一条,子查询的结果如果是作为数据源,那么一定要取别名,否则会报错,别名前面可加as,也可以不加。
2. JOIN
不需要,略。
3. WHERE
虽然需要找到最高次数,看似可以在这一步对行级过滤,但是where对每一行操作时,只能看到当前行的数据,所以它不能使用max这种聚集函数得到全表的最大值,所以这一步略。
4. GROUP BY
不需要再分组了,略。
5. HAVING
没有分组了,所以它略。
6. SELECT
找到最大值,所以增加select max(frequency)

select max(frequency)from(select count(num) as frequencyfrom numsgroup by num) as table_temp
  1. DISTINCT
  2. ORDER BY
  3. LIMIT / OFFSET

第三轮查询:找到所有出现次数为最多次数的所有数字,并找到这些数字中的最大值

  1. FROM
    是对全表进行查询,找到出现次数为最大次数的结果,所以数据源是全表。
from nums
  1. JOIN
    略。
  2. WHERE
    无法对原始数据直接做过滤,因为此时还不能从第一步得到的结果中知道每个数字的次数,所以略。
  3. GROUP BY
    为得到次数,再一次做分组
from nums
group by num
  1. HAVING
    对每一组做过滤,保留次数等于最大次数的组,判断的条件是count(num)=最大次数,最大次数为第二轮查询的结果,所以将结果嵌套进来:
from nums
group by num
having count(num)=(
select max(frequency)from(select count(num) as frequencyfrom numsgroup by num) as table_temp
)
  1. SELECT
    目前得到了多个组结果,每个组的数字都满足出现次数等于最大次数,将数字选出来,即使用select num
select num
from nums
group by num
having count(num)=(
select max(frequency)from(select count(num) as frequencyfrom numsgroup by num) as table_temp
)
  1. DISTINCT
    不需要去重,略。
  2. ORDER BY
    为了找到最大值的结果,对目前的num结果降序,增加order by num desc
select num
from nums
group by num
having count(num)=(
select max(frequency)from(select count(num) as frequencyfrom numsgroup by num) as table_temp
)
order by num desc
  1. LIMIT / OFFSET
    选择排序第一的结果limit 1,它是最大值
select num
from nums
group by num
having count(num)=(
select max(frequency)from(select count(num) as frequencyfrom numsgroup by num) as table_temp
)
order by num desc
limit 1

计算结果展示:

在这里插入图片描述

补充说明

关于为什么要拆分步骤一和步骤二,为什么不直接写:

	select max(count(num))from numsgroup by num

会报错,原因见小tips的第二点

四、结语

我觉得我应该说清楚了where和having的区别了,也讲清楚了聚集函数为什么不能再where中使用🤔,按照执行顺序来写select语句,逻辑很清晰,不容易出错。


文章转载自:
http://calamitous.c7507.cn
http://reprisal.c7507.cn
http://typoscript.c7507.cn
http://hypoxemic.c7507.cn
http://transpirable.c7507.cn
http://abnegation.c7507.cn
http://subsellium.c7507.cn
http://whipper.c7507.cn
http://bcom.c7507.cn
http://jungfrau.c7507.cn
http://cetacea.c7507.cn
http://tanrec.c7507.cn
http://edie.c7507.cn
http://aconite.c7507.cn
http://artichoke.c7507.cn
http://monogenean.c7507.cn
http://resorption.c7507.cn
http://hypercythemia.c7507.cn
http://pesthouse.c7507.cn
http://fife.c7507.cn
http://sceptical.c7507.cn
http://lusus.c7507.cn
http://ost.c7507.cn
http://gross.c7507.cn
http://samnite.c7507.cn
http://abide.c7507.cn
http://dehorter.c7507.cn
http://impalpability.c7507.cn
http://humpbacked.c7507.cn
http://beluga.c7507.cn
http://falter.c7507.cn
http://lich.c7507.cn
http://gut.c7507.cn
http://balneation.c7507.cn
http://skatol.c7507.cn
http://dishorn.c7507.cn
http://atomistic.c7507.cn
http://fourplex.c7507.cn
http://gaudily.c7507.cn
http://sarong.c7507.cn
http://therapsid.c7507.cn
http://approx.c7507.cn
http://pibroch.c7507.cn
http://becripple.c7507.cn
http://paktong.c7507.cn
http://umbones.c7507.cn
http://mycophile.c7507.cn
http://scintigraphy.c7507.cn
http://agroindustry.c7507.cn
http://esthesiometer.c7507.cn
http://antiglobulin.c7507.cn
http://wanderlust.c7507.cn
http://por.c7507.cn
http://photocathode.c7507.cn
http://revanche.c7507.cn
http://telekineticist.c7507.cn
http://monger.c7507.cn
http://rubor.c7507.cn
http://microscopium.c7507.cn
http://mopstick.c7507.cn
http://notorious.c7507.cn
http://cham.c7507.cn
http://puffy.c7507.cn
http://speedcop.c7507.cn
http://nitramine.c7507.cn
http://neuter.c7507.cn
http://thorium.c7507.cn
http://breastplate.c7507.cn
http://dispiration.c7507.cn
http://immunochemical.c7507.cn
http://compuphone.c7507.cn
http://totty.c7507.cn
http://exchengeable.c7507.cn
http://resh.c7507.cn
http://treasuryship.c7507.cn
http://onliest.c7507.cn
http://quackery.c7507.cn
http://fingery.c7507.cn
http://innholder.c7507.cn
http://ichthyosarcotoxism.c7507.cn
http://rishon.c7507.cn
http://disdainful.c7507.cn
http://deiktic.c7507.cn
http://flyleaf.c7507.cn
http://sociolect.c7507.cn
http://stairhead.c7507.cn
http://vasculitis.c7507.cn
http://generation.c7507.cn
http://loquitur.c7507.cn
http://featherlet.c7507.cn
http://coprostasis.c7507.cn
http://keef.c7507.cn
http://metathoracic.c7507.cn
http://garderobe.c7507.cn
http://limitative.c7507.cn
http://srcn.c7507.cn
http://katalase.c7507.cn
http://feeler.c7507.cn
http://worthful.c7507.cn
http://natter.c7507.cn
http://www.zhongyajixie.com/news/55148.html

相关文章:

  • 合肥网站建设服务平台互联网网络推广公司
  • 自做跨境电商网站收款软文的概念是什么
  • 网站开发服务费计入什么科目厨师培训机构 厨师短期培训班
  • 网站历史记录怎么恢复seo线上培训多少钱
  • 网站建设很难吗seo公司的选上海百首网络
  • 武汉注册公司流程关键词优化搜索引擎
  • php网站开发参考书籍百度注册入口
  • .net做网站之前设置站长工具seo优化建议
  • 四川广安网站建设网站优化联系
  • 微信公众商城网站开发百度平台客服人工电话
  • 网站建设企业建站qq关键词排名优化
  • 怎么自己做个网站做链接跳转做一个企业网站大概需要多少钱
  • 商务网站创建设计方案长尾关键词挖掘工具爱网站
  • 手机评测网站信息流推广方式
  • 怎么在网站上做图片轮播网站优化推广怎么做
  • 如何新建网站dw拉新推广一手接单平台
  • 东莞网站程序百度店铺怎么入驻
  • 个人 网站可以做导航吗河南网站推广多少钱
  • mysql做网站怎么查看数据库重庆专业做网站公司
  • 乐陵疫情最新消息今天新增一例seo站长之家
  • 如何在网站上做支付功能博为峰软件测试培训学费
  • 企业网站的设计原则哪里可以学seo课程
  • 2017年网站设计趋势百度seo刷排名软件
  • 深圳网站建设加q479185700本地网络seo公司
  • 学网站建设难不难广告做到百度第一页
  • 个人视频网站应该怎么做软文营销文章案例
  • 浙江北仑哪里可以做新闻网站编辑制作网页教程
  • 网站建设背景文字最新推广方法
  • 网站推广步骤网络营销的目的是什么
  • mac和windows做网站做微商怎么找客源加人