首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ThinkPHP5.1 子查询-使用 Group 获取每组最新数据

背景 当前项目业务中, 需要以字段 account_id 分组,获取 "redbook_effect" 数据表中最新的数据记录集合 - 根据网上的经验描述,如果 group 和 order 一起使用...- 会先进行分组获取, - 再对得到的结果集进行排序 - 所以如此一来,得到的最终数据中,对应字段 "account_id" 的记录并非是最新的 ---- 解决方案:【使用子查询,先进行排序...,再分组】 参考文档 【ThinkPHP5 开发文档 —— 子查询】 【where,group by,having,order by 执行顺序和编写顺序】 处理源码如下: $where =...') ->order('id desc') ->where($where) ->buildSql(); //然后使用子查询构造新的查询...a ,否则会报错: "Every derived table must have its own alias" 总结: 因为在嵌套查询中,子查询的结果是作为一个派生表给上一级进行查询,所以子查询的结果必须有一个别名

2.3K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL高级知识:派生表

    SQL刷题专栏 SQL145题系列 派生表的定义 派生表是在外部查询的FROM子句中定义的,只要外部查询一结束,派生表也就不存在了。 派生表的作用 派生表可以简化查询,避免使用临时表。...派生表与其他表一样出现在查询的FROM子句中。...不允许使用ORDER BY(除非指定了TOP) 派生表必须指定名称,例如:Cus 注意:派生表是一张虚表,在数据库中并不存在,是我们自己创建的,目的主要是为了缩小数据的查找范围,提高查询效率。...在这个例子中,使用嵌套派生表的目的是为了重用列别名。但是,由于嵌套增加了代码的复杂性,所以对于本例考虑使用方案一。 与子查询的区别 子查询是指在主查询中使用的内部查询。...仅限⼦查询返回单⾏单列的情况。 1、派生表通常出现在FROM子句后面。 2、派生表通常用于子查询的结果需要多次使用的场景,而子查询可以用于需要临时结果的场景。

    17710

    【数据库SQL server】关系数据库标准语言SQL之视图

    (即子查询中的条件表达式) 子查询可以是任意的SELECT语句,是否可以含有ORDER BY子句和DISTINCT短语,则决定具体系统的实现。...组成视图的属性列名:全部省略或全部指定 全部省略: 由子查询中SELECT目标列中的诸字段组成 明确指定视图的所有列名: 某个目标列是聚集函数或列表达式 多表连接时选出了几个同名列作为视图的字段...若视图定义中含有GROUP BY子句,则此视图不允许更新。 若视图定义中含有DISTINCT短语,则此视图不允许更新。...若视图定义中有嵌套查询,并且内层查询的FROM子句中涉及的表也是导出该视图的基本表,则此视图不允许更新。...一个不允许更新的视图上定义的视图也不允许更新 【1】将SC中成绩在平均成绩之上的元组定义成一个视图 CREATE VIEW GOOD_SC AS SELECT

    19510

    客快物流大数据项目(九十七):ClickHouse的SQL语法

    但该子句与GROUP BY子句存在以下几点不同:可以与GROUP BY配合使用;当不存在ORDER BY子句但存在LIMIT子句时,查询将在同时满足DISTINCT与LIMIT的情况下立即停止查询;在处理数据的同时输出结果...FROM子句规定了将从哪个表、或子查询、或表函数中读取数据;同时ARRAY JOIN子句和JOIN子句也可以出现在这里。...执行查询时,在查询中列出的所有列都将从对应的表中提取数据;如果你使用的是子查询的方式,则任何在外部查询中没有使用的列,子查询将从查询中忽略它们;如果你的查询没有列出任何的列(如SELECT count(...因此,为了显示的指定执行顺序,建议使用子查询的方式执行JOIN。子查询不允许设置别名或在其他地方引用它们。USING中指定的列必须在两个子查询中具有相同的名称,而其他列必须具有不同的名称。...可以通过使用别名的方式来更改子查询中的列名。USING子句使用的是等值连接。右表(子查询的结果)将会保存在内存中。如果没有足够的内存,则无法运行JOIN。只能在查询中指定一个JOIN。

    3.3K61

    SQL 嵌套查询 —比较 很有用「建议收藏」

    其中外层查询也称为父查询,主查询。内层查询也称子查询,从查询。   嵌套查询的工作方式是:先处理内查询,由内向外处理,外层查询利用内层查询的结果嵌套查询不仅仅可以用于父查询select语句使用。...2、包含一个或多个表或者视图名称的标准from子句。   3、可选的where子句。   4、可选的group by子句。   5、可选的having子句。...二、子查询的语法规则   1、子查询的select查询总是使用圆括号括起来。   2、不能包括compute或for.browse子句。   ...5、任何可以使用表达式的地方都可以使用子查询,只要它返回的是单个值。   6、如果某个表只出现在子查询中二不出现在外部查询中,那么该表的列就无法包含在输出中。...exists 子查询            其中子查询是一个首先的select语句,不允许有compute子句和into关键字。    exists 的意思是,子查询是否有结果集返回。

    74830

    HIVE基础命令Sqoop导入导出插入表问题动态分区表创建HIVE表脚本筛选CSV中的非文件行GROUP BYSqoop导出到MySQL字段类型问题WHERE中的子查询CASE中的子查询

    source_sys_key AND temp.legal_company = t0.legal_company ) where temp.jobid = '106'; // 在创建表的时候通过从别的表中查询出相应的记录并插入到所创建的表中...后面的非聚合列必须出现在group by中,所以得这么写 SELECT c1,c2,c3, count(0) FROM table_a GROUP BY c1,c2,c3; 那能不能不 GROUP BY...collect_set 和 GROUP BY 一起使用的场景,应该是这样的:想查出A、B两个字段,但是只想对A分组,只需要随便取出A组里面的一个B,这种时候是可以用的。...WHERE中的子查询 在hive中的子查询会有各种问题,这里的解决方法是将子查询改成JOIN的方式 先看一段在MySQL中的SQL,下不管这段SQL从哪来的,我也不知道从哪里来的 SELECT...CASE中的子查询 这个与上面是一样的,都是改成JOIN的方式。

    15.4K20

    SQL命令 FROM(二)

    FROM子句中的子查询 可以在FROM子句中指定子查询。 这称为流子查询。 子查询被视为与表相同的处理方式,包括它在JOIN语法中的使用以及使用as关键字可选地分配别名。...当与TOP子句配对时,子查询可以包含ORDER BY子句。 子查询可以使用SELECT *语法,但有以下限制:因为FROM子句的结果是值表达式,所以包含SELECT *的子查询只能生成一列。...子查询中的连接不能是NATURAL连接或接受USING子句。 从子查询和%VID 当调用FROM子查询时,它为返回的每个子查询行返回一个%VID。...因为%VID是一个顺序整数,所以可以用它来确定带有ORDER BY子句的子查询中项目的排名。...下面的例子省略了FROM子句。 DISTINCT关键字不是必需的,但是可以指定。 不允许使用SELECT子句。

    1.7K40

    在 SQL 中,如何使用子查询来获取满足特定条件的数据?

    在 SQL 中,可以使用子查询来获取满足特定条件的数据。子查询是嵌套在主查询中的查询语句,它返回一个结果集,可以用来过滤主查询的结果。...下面是使用子查询来获取满足特定条件的数据的一般步骤: 在主查询中使用子查询,将子查询的结果作为条件。 子查询可以在主查询中的 WHERE 子句、FROM 子句或 HAVING 子句中使用。...子查询可以返回单个值或多个值,具体取决于使用的运算符和子查询的语法。 以下是一些示例: 使用子查询在 WHERE 子句中过滤数据: SELECT column1, column2, ......FROM (SELECT column FROM table WHERE condition) AS temp_table; 使用子查询在 HAVING 子句中过滤数据: SELECT column1,...FROM table GROUP BY column1 HAVING column1 > (SELECT AVG(column1) FROM table); 请注意,子查询的性能可能会较低,因此在设计查询时应谨慎使用

    24210

    SQL中的聚合函数使用总结

    一般在书写sql的是时候很多时候会误将聚合函数放到where后面作为条件查询,事实证明这样是无法执行的,执行会报【此处不允许使用聚合函数】异常。为什么会报异常呢?...其原因很简单: having放在group by 的后面 group by 后面只能放非聚合函数的列 where 子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据...,条件中不能包含聚组函数,使用where条件显示特定的行。...那聚合函数在什么情况下使用或者应该处在sql文中的哪个位置呢 聚合函数只能在以下位置作为表达式使用: select 语句的选择列表(子查询或外部查询); compute 或 compute by 子句...; having 子句; 其实在诸多实际运用中,聚合函数更多的是辅助group by 使用,但是只要我们牢记where的作用对象只是行,只是用来过滤数据作为条件使用。

    1.9K10

    mysql嵌套子查询的应用

    还可以用于insert、update、delete语句或其他子查询中。 子查询的组成 包含标准选择列表组件的标准select查询 包含一个或多个表或者视图名称的标准from子句。...可选的where子句。 可选的group by子句。 可选的having子句。 子查询的语法规则 子查询的select查询总是使用圆括号括起来 不能包括compute或for.browse子句。...如果同时指定top子句,则可能只包括order by子句。 子查询最多可以嵌套到32层。个别查询可能会不支持32层嵌套。 任何可以使用表达式的地方都可以使用子查询,只要它返回的是单个值。...如果某个表只出现在子查询中而不出现在外部查询中,那么该表的列就无法包含在输出中。...exists 子查询  其中子查询是一个首先的select语句,不允许有compute子句和into关键字。exists 的意思是,子查询是否有结果集返回。

    4.2K20

    MySQL中的WITH ROLLUP子句:优化数据分析与汇总

    在MySQL中,优化数据查询和生成报表是至关重要的任务,WITH ROLLUP是一个用于在查询结果中生成合计行的特殊子句。...它可以在GROUP BY子句中使用,以在结果中添加额外的行,显示分组的合计值。...多级合计行:如果在GROUP BY子句中指定了多个列,那么WITH ROLLUP会生成多级合计行,每个级别都包含前面分组列的合计值。...BY DATE( login_time ) WITH ROLLUP 使用WITH ROLLUP 子句我们将很容易得到一个统计行数据,结果如下 总结: MySQL中的WITH ROLLUP子句是一个强大的数据分析工具...通过合理使用WITH ROLLUP子句,我们可以优化数据查询和报表生成的过程,提高数据分析的效率和准确性。

    2.2K40

    MySQL 查询专题

    ❑ 大多数SQL实现不允许 GROUP BY 列带有长度可变的数据类型(如文本或备注型字段)。 ❑ 除聚集计算语句外,SELECT 语句中的每一列都必须在 GROUP BY 子句中给出。...使用 HAVING 时应该结合GROUP BY 子句,而 WHERE 子句用于标准的行级过滤。 一般在使用 GROUP BY 子句时,应该也给出 ORDER BY 子句。...子查询 版本要求 MySQL 4.1 引入了对子查询的支持,所以要想使用本章描述的 SQL,必须使用MySQL 4.1 或更高级的版本。...where item_price >= 10 ) 列必须匹配 在 WHERE 子句中使用子查询(如这里所示),应该保证SELECT语句具有与 WHERE 子句中相同数目的列。...通常,子查询将返回单个列并且与单个列匹配,但如果需要也可以使用多个列。 虽然子查询一般与IN操作符结合使用,但也可以用于测试等于(=)、不等于()等。

    5K30

    T-SQL基础(三)之子查询与表表达式

    子查询 在嵌套查询中,最外面查询结果集返回给调用方,称为外部查询。嵌套在外部查询内的查询称为子查询,子查询的结果集供外部查询使用。 根据是否依赖外部查询,可将子查询分为自包含子查询和相关子查询。...子查询中很有可能无意中包含了外部查询的列名导致子查询有自包含子查询变为相关子查询而引发逻辑错误。 为避免上述错误,查询中的列名尽可能使用完全限定名:[表名].[列名]。...标准SQL中不允许在表表达式中使用ORDER BY子句,除非ORDER BY子句用于展示之外的其他目的,否则会报错: 除非另外还指定了 TOP、OFFSET...或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效....派生表 派生表又称为子查询表,在外部查询的FROM子句中进行定义,一旦外部查询结束,派生表也就不复存在。

    1.6K40

    SQL优化(五) PostgreSQL (递归)CTE 通用表表达式

    如果WITH里面使用的不是SELECT语句,并且没有通过RETURNING子句返回结果集,则主查询中不可以引用该CTE,但主查询和WITH语句仍然可以继续执行。...而WITH中的SELECT语句则只输出主语句中所需要记录数。 WITH中使用多个子句时,这些子句和主语句会并行执行,所以当存在多个修改子语句修改相同的记录时,它们的结果不可预测。...FULL JOIN recursive term中不允许使用GROUP BY和HAVING 不允许在recursive term的WHERE语句的子查询中使用CTE的名字 不支持在recursive term...term中使用 recursive term中SELECT后面不允许出现引用CTE名字的子查询 同时使用多个CTE表达式时,不允许多表达式之间互相访问(支持单向访问) 在recursive term中不允许使用...,且可在主查询中多次使用 CTE可极大提高代码可读性及可维护性 CTE不支持将主查询中where后的限制条件push down到CTE中,而普通的子查询支持

    2.6K60

    数据库SQL语言从入门到精通--Part 4--SQL语言中的模式、基本表、视图

    > [WITH CHECK OPTION]; 子查询可以是任意的SELECT语句,是否可以含有ORDER BY子句和DISTINCT短语,则决定具体系统的实现 WITH CHECK OPTION:对视图进行...UPDATE,INSERT和DELETE操作时要保证更新、插入或删除的行满足视图定义中的谓词条件(即子查询中的条件表达式) 注: 修改基表的结构后,可能导致表与视图的映象关系被破坏,从而导致该视图不能正确工作...组成视图的属性列名:全部省略或全部指定 子查询不允许含有ORDER BY子句和DISTINCT短语 全部省略或全部指定 省略:由子查询中SELECT目标列中的诸字段组成 明确指定视图的所有列名:...(4) 若视图定义中含有GROUP BY子句,则此视图不允许更新。 (5) 若视图定义中含有DISTINCT短语,则此视图不允许更新。...(6) 若视图定义中有嵌套查询,并且内层查询的FROM子句中涉及的表也是导出该视图的基本表,则此视图不允许更新。

    2.2K10

    T-SQL基础(三)之子查询与表表达式

    子查询 在嵌套查询中,最外面查询结果集返回给调用方,称为外部查询。嵌套在外部查询内的查询称为子查询,子查询的结果集供外部查询使用。 根据是否依赖外部查询,可将子查询分为自包含子查询和相关子查询。...子查询中很有可能无意中包含了外部查询的列名导致子查询有自包含子查询变为相关子查询而引发逻辑错误。 为避免上述错误,查询中的列名尽可能使用完全限定名:[表名].[列名]。...标准SQL中不允许在表表达式中使用ORDER BY子句,除非ORDER BY子句用于展示之外的其他目的,否则会报错: 除非另外还指定了 TOP、OFFSET 或 FOR XML,否则,ORDER BY...子句在视图、内联函数、派生表、子查询和公用表表达式中无效....派生表 派生表又称为子查询表,在外部查询的FROM子句中进行定义,一旦外部查询结束,派生表也就不复存在。

    1.5K10

    『数据库』震惊,某博主为吸引眼球拿出压箱底SQL总结,如果你没看那就吃亏了!(超级详细的SQL基础,你还不会的话就别学数据库了)

    > [WITH CHECK OPTION]; 子查询可以是任意的SELECT语句,是否可以含有ORDER BY子句和DISTINCT短语,则决定具体系统的实现 WITH CHECK OPTION:对视图进行...UPDATE,INSERT和DELETE操作时要保证更新、插入或删除的行满足视图定义中的谓词条件(即子查询中的条件表达式) 注: 修改基表的结构后,可能导致表与视图的映象关系被破坏,从而导致该视图不能正确工作...组成视图的属性列名:全部省略或全部指定 子查询不允许含有ORDER BY子句和DISTINCT短语 全部省略或全部指定 省略:由子查询中SELECT目标列中的诸字段组成 明确指定视图的所有列名:...(4) 若视图定义中含有GROUP BY子句,则此视图不允许更新。 (5) 若视图定义中含有DISTINCT短语,则此视图不允许更新。...(6) 若视图定义中有嵌套查询,并且内层查询的FROM子句中涉及的表也是导出该视图的基本表,则此视图不允许更新。 (7) 一个不允许更新的视图上定义的视图也不允许更新 别吝啬一个?。

    72930

    数据库相关

    (最为麻烦的地方为此处的限制) 注意事项一: 如果一个查询之中不存在group by 子句,select子句中只允许出现统计函数,其他任何字段都不允许出现 select deptno ,count(*)...from emp; 提示”不是单组分组函数“错误 注意事项二: 在统计查询之中(存在group by子句) select子句中只允许出现分组字段(group by后面的字段)和统计函数其他任何字段都不允许出现...having子句必须和group by子句一起使用 查询出所有平均工资大于2000的职位信息、平均工资和雇员人数 select job,round(avg(sal)),count(empno) from...,名称,并统计出这些部门的平均工资、最低工资、最高工资 1、确定所需要的数据表 2、确定已知的关联字段: 子查询 子查询中的语法格式并没有任何新的技术,类似于java的内部类,而且在开发之中,子查询的使用绝对是比较多的...: 单独使用:不允许出现任何字段 和group by一起使用:允许出现分组字段 范例:查询出所有的新近高于公司平均薪金的员工编号、姓名、基本工资、职位、雇佣日期、所在部门名称、位置、上级领导姓名、公司的等级

    1.9K50
    领券