SQL: select非group by的字段

简介: SQL: select非group by的字段

使用group by查找或删除重复行,请参考

在含有Group by子句的查询语句中,对select关键字后的目标列,存在以下规律

  1. 使用group by 时,select 涉及的列要么是参与分组的列,要么列包含在聚合函数中
  2. where将对分组前的所有数据进行筛选。having将对分组后的一组数据搞事情。

例如:

select a,b,avg(c),sum(d) from 表 group by a,b


select非group by的字段

  • 可以把group by的结果集当作一个表,然后从这里表里取数就可以了
  • 例如:查询,订单表中订单号重复的订单信息,分组字段是orderno,select的信息不仅有orderno,还有其他信息
SELECT
  p.id,
  p.orgcode,
  p.idserial,
  p.username,
  p.orderno,
  p.createtime,
  p.payflag,
  p.businessorderno,
  p.paytime
FROM
  pay_order_trade p,
  (
    SELECT
      orderno,
      count(*) 重复次数
    FROM
      pay_order_trade
    GROUP BY
      orderno
    HAVING
      count(1) > 1
  ) s
WHERE
  s.orderno = p.orderno
ORDER BY
  p.orderno DESC;



目录
相关文章
|
1月前
|
SQL 存储 数据库
SQL部分字段编码设置技巧与方法
在SQL数据库管理中,设置字段的编码对于确保数据的正确存储和检索至关重要
|
30天前
|
SQL 存储 Serverless
SQL语句拆分时间字段的技巧与方法
在数据库操作中,经常需要处理时间数据
|
1月前
|
SQL 存储 关系型数据库
SQL判断CHAR类型字段不为空的方法与技巧
在SQL查询中,判断一个CHAR类型字段是否不为空是一个常见的需求
|
1月前
|
SQL Oracle 关系型数据库
SQL如何添加字段记录:详细步骤与技巧
在数据库管理中,经常需要向已有的表中添加新的字段(列)或向表中插入新的记录
|
2月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
44 1
|
2月前
|
SQL 关系型数据库 MySQL
MySQL根据某个字段包含某个字符串或者字段的长度情况更新另一个字段的值,如何写sql
MySQL根据某个字段包含某个字符串或者字段的长度情况更新另一个字段的值,如何写sql
171 0
|
3月前
|
SQL 数据挖掘 关系型数据库
|
3月前
|
SQL
访问者模式问题之构造一个包含 select、from 和 where 子句的 SQL 节点树,如何解决
访问者模式问题之构造一个包含 select、from 和 where 子句的 SQL 节点树,如何解决
|
2月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
4月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
111 13