sql的性能优化之——distinct与group by

  1. 表A (uid,bid) ,
    uid代表:用户id
    bid代表:uid关注的用户id
    表数据示例:
    uid bid


         1 2
         2 1
         1 3

------我的答案

selectt1.uid,t1.bid
from tbl t1
join(selectuid,bidfrom tbl)t2
on t1.uid = t2.bid and t1.bid = t2.uid

实际上,一需要考虑到数据中的去重问题

chatgpt提供

使用distinct
1.对数据去重
distinct uid,bid
2.再加一个顺序排序
order by bid,uid

3.综合sql

SELECT DISTINCT t1.uid, t1.bid
FROM tab t1
JOIN tableA t2 ON t1.uid = t2.bid AND t1.bid = t2.uid
ORDER BY t1.uid, t1.bid;
-----对于性能,考虑到使用group by 
1.使用union
selectuid,bid
from tbl 
union
selectbid,uid
from tbl
2.进行筛选过滤数据
selectuid,bid
from tbl 
where (uid,bid) in ()t1
3.去重分组
selectuid,bid,count(*) 
from t2
group by uid,bid
4.过滤数据为2
selectuid,bid
from tbl
having count(*) = 2
5.综合sql
SELECT uid, bid
FROM tableA
WHERE (uid, bid) IN (SELECT uid, bidFROM tableAUNIONSELECT bid, uidFROM tableA
)
GROUP BY uid, bid
HAVING COUNT(*) = 2;
--- 发现having用法

意外发现,使用group by 的时候,聚合可以直接在having后面完成,无需写在select这里。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/593957.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java程序设计阶段测试1

一、单选题(共15题; 共30.0分) 2.0分 1、以下哪个是Java应用程序main方法的有效定义? A.public static void main(); B.public static void main( String args ); C.public static void main( String args[] ); D.public static boolea…

Go Lang Fiber介绍

利用GoLang Fiber进行高性能Web开发 在不断发展的Web开发世界中,选择合适的框架至关重要。速度、简洁性和强大的功能集是每个开发者都追求的品质。在使用Go构建Web应用时,“Fiber”作为一个强大且轻量级的框架在众多选择中脱颖而出。在这份全面的指南中…

扩展:键盘录入笔记(next()、nextLine()、nextInt()、nextDouble())

文章目录 一,键盘录入涉及到的方法如下:1)next()、nextLine():代码示例:代码示例: 2)nextInt():代码示例&…

java静态代理动态代理理解和例子解析包含demo

demo 基本背景 // 背景: 有一家甜品点,有2类机器,面包和蛋糕机器, 接口 BreadMachine CakeMachine // 面包机器有蜂蜜和黄油2种,类 BreadButter BreadBee // 蛋糕机器有水果和巧克力2种,类 CakeFruit CakeChocolate package com.ah.test.proxy.shop1; // 面包…

无辅源电压继电器 RWY-D2/3 180-440VAC 导轨安装 josef约瑟

RWY-D1型电压继电器; RWY-D2型电压继电器; 一、 概述 RWY-D系列电压继电器(以下简称本继电器)用于发电机、变压器和输电线的电器保护装置中,作为过电压保护或低电压闭锁的启动原件。本继电器为集成电路静态型继电器…

设计模式--适配器模式

适配器模式 适配器模式(Adapter),将一个类的接口转换为客户希望的另一个接口,Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。 系统的数据和行为都正确,但接口不符合时,我们应该…

Python入门学习篇(十七)——封装、继承、多态

1 封装 1.1 理解 属性和方法书写到类里面的操作即为封装 封装可以理解成私有化属性和私有化方法1.2 示例代码 class Person():p_num 0 # 用于统计数量def __init__(self, name, age, sex, job):# __name为私有化属性self.__name nameself.age ageself.sex sexself.job …

使用anaconda创建爬虫spyder工程

1.由于每个工程使用的环境都可能不一样,因此一个好的习惯就是不同的工程都创建属于自己的环境,在anaconda中默认的环境是base,我们现在来创建一个名为spyder的环境,专门用于爬虫工程: //括号中名字,代表当…

森林火灾数据集

野外火灾是全球范围内最致命和危险的天然灾害之一。它不仅对人类的生命安全构成严重威胁,还对动植物的生存环境造成巨大的破坏。预测火灾行为不仅可以帮助消防员更好地应对火情,还可以为未来的火灾预防和应对策略提供有力支持。 随着航空图像技术的不断…

Windows可以ping通ubuntu,但ubuntu无法ping通windows

使用了NAT网卡和桥接网卡,电脑连了WiFi,桥接网卡桥接到WLAN上,Windows可以ping通Ubuntu但反过来不行! 1.可能是防火墙的问题,按照如下设置,无果 考虑是不是使用了两个网卡冲突了,取消NAT的链接 …

【笔记】书生·浦语大模型实战营——第一课

群公告 1月3日*更新 第一次课程视频链接:https://www.bilibili.com/video/BV1Rc411b7ns/,第一次课程只需要记笔记,没有作业。第一次课程(1月3日)和第二次课程(1月5日)到本周末(1月7日)截止,笔记记录在 知乎/CSDN/Github 或者任何你…

Mysql数据库:select from语句详解

Mysql数据库:select from语句详解 一、select from语句概述二、select from语句的基本用法三、select from语句的示例1、查询所有列2、查询特定列3、查询带有条件的数据(过滤)4、查询结果排序5、查询结果限制6、查询结果去重7、查询结果分组8…

【操作系统xv6】学习记录--实验1 Lab: Xv6 and Unix utilities--未完

ref:https://pdos.csail.mit.edu/6.828/2020/xv6.html 实验:Lab: Xv6 and Unix utilities 环境搭建 实验环境搭建:https://blog.csdn.net/qq_45512097/article/details/126741793 搭建了1天,大家自求多福吧,哎。~搞环境真是折磨…

QProgressDialog用法及结合QThread用法,四种线程使用

1 QProgressDialog概述 QProgressDialog类提供耗时操作的进度条。 进度对话框用于向用户指示操作将花费多长时间,并演示应用程序没有冻结。此外,QPorgressDialog还可以给用户一个中止操作的机会。 进度对话框的一个常见问题是很难知道何时使用它们;操作…

Document对象详解

前言 在前端开发中,DOM(文档对象模型)扮演着重要的角色。它允许我们使用JavaScript来与网页文档进行交互,实现动态的网页效果。DOM的核心部分之一就是Document对象,它代表了整个HTML文档。在本篇博客中,我们…

华媒舍:6个使你的媒体发稿推广更简单的方法!

做为新闻报道媒体从业人员,在宣传发稿上要行走在最前沿,保持竞争力。下面我们就向您介绍六个又简单又实用的方法,帮助你提升新闻报道媒体营销推广发稿效果。 方法一:明确目标群体我们应该明确定义我们自己的目标群体。掌握观众的特…

爬虫如何获取免费代理IP(一)

随着网络爬虫技术的日益发展,获取和使用免费代理IP已成为许多爬虫工作者关注的焦点。免费代理IP不仅能够帮助爬虫隐藏真实身份,还能提高数据抓取的效率。然而,在实际应用中,免费代理IP也带来了一系列挑战。接下来我提供三个篇文章…

小H靶场笔记:DC-3

DC-3 January 3, 2024 4:11 PM Tags:Joomla owner:只惠摸鱼 信息收集 探测靶机ip: 192.168.199.133 nmap 扫描端口、 系统版本 漏洞 发现只有80端口开发, 且有cve-2017-8917漏洞存在是Joomla的SQL注入漏洞 Joomla版本为3.7.0…

Docker安装Superset

文章目录 拉取镜像安装创建目录运行Superset容器设置用户名密码初始化数据库服务初始化启动superset服务访问服务 拉取镜像 docker pull amancevice/superset查看拉取的镜像ID [rootbigdata ~]# docker images REPOSITORY TAG IMAGE…

SpringBoot-SpringSecurity

Spring Security 中文文档&#xff1a;https://springdoc.cn/spring-security/ Thymeleaf&#xff1a;https://www.thymeleaf.org/ 依赖 <!--security-thymeleaf 前端验证--> <!--<dependency><groupId>org.thymeleaf.extras</groupId><artifac…