百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

SQL用了两年多,分享2个最常用的小技巧

itomcoil 2025-07-09 13:22 16 浏览

导读:SQL是所有数据从业者必须打牢的基本功之一,扎实的SQL查询和适当的调优技巧是检验SQL能力的两大重要准则。个人曾经专门花费过好多时间用于提升SQL能力,期间也刷了大量的SQL题目,在这期间也不断摸索总结了一些小技巧,今天本文就来分享其中的两个,也差不多是日常使用中最为高频的两个了。


作者 | luanhz 责编 | 欧阳姝黎
为了配合演示这两个小技巧,本文所使用示例数据如下,其实这也是前几天推文中所使用的数据:

示例学生成绩表


SQL的数据类型隐式转换


很多编程语言都限定了数据类型,例如在Python中字符串"0"和数值0是不相等的,布尔型True和数值1也是不相等,但在SQL中则不然,其内置了数据类型隐式转换功能,所以执行查询 select "0"=0 会返回1的,这既说明字符串"0"和数值0是相等的,也说明SQL中的布尔值会自动转换为1或0。

利用这一小技巧,在实现很多统计指标时就可以有很多小技巧。例如计算学生成绩表中每名学生的成绩的优秀率,即成绩在90分以上的科目与本人总科目的占比。为实现这一查询,常规的操作是分别统计每名学生成绩在90分以上的科目数量和总科目,然后进行相除得到占比。

实际上,在给出前述小例子的基础上,这一需求可以如下实现:

其中,在每名学生的分组中,条件判断score>=90返回一组0或1的结果,对这组0/1取值进行求均值操作,即等价于求成绩>=90的科目占比。


巧妙运用if函数和


SQL内置了众多函数,但对于一名程序员而言if函数应该尤为常见和常用;另一方面,值也是SQL中一个神奇的存在,它有两大特性:一是任何值与的任何计算都会得到值;二是在任何聚合函数中,值都不参与计算(例如,count计数就是查找以外的结果数量)。配合使用if函数和值,有时也可实现很好的效果。

例如,仍然针对以上学生成绩表,需要分别统计每名学生成绩在80分以上成绩的平均值,也就是如果成绩>=80则参与最后均值计算,否则不参与。配合if函数和的特性,可以如下优雅的实现:

实际上,上述查询语句中,首先通过if函数衍生一个临时字段if(score>=80, score, )其取值为:成绩≥80时取成绩值,否则置为,即相当于仅保留了成绩在80分以上的记录;而后嵌套一层avg函数即直接实现了计算80分以上平均值的效果。

当然,对于这一需求也可以先用where条件过滤出成绩在80分以上的记录后再聚合统计。

相关推荐

「满满干货」让你的Win10变得更好用的3款小软件

大家好我是非凡资源-李李,休息两天这又来给大家带来几款好用的电脑软件,电脑小白也好还是老手都能用的到的。开始吧快来看看吧。一.XMediaRecode软件介绍XMediaRecode是一款免费的视...

AI指导:打造第一个Python应用(4)_第一个python例子

眼瞅着迈过几个里程碑,与目标越来越近。尽管过程中照旧因返工而心焦,而欣喜与急躁比例,是喜悦运大于焦虑。从初次熟悉智能大模型,尝试编程起步,不定期进行复盘反思,这是小助手指导编程的第四篇。复盘以为记。需...

AI超助:打造第一个Python应用(III)

这是小助手指导编程的第三篇。第一篇AI辅助编程,依照步骤;学习编程同时开展编程乐趣与挑战。第一篇围绕如何熟悉智能大模型,尝试起步,能否坚持下来,其实心中没底。以文稿方式披露,也就是一种自我监督。第二篇...

LPL比赛数据可视化,完成这个项目,用尽了我的所有Python知识

LPL比赛数据可视化效果图完成这个项目,我感觉我已经被掏空了,我几乎用尽了我会的所有知识html+css+javascript+jQuery+python+requests+numpy+mysql+p...

AI,Gpt4.0教你编程,实现清理文件工具

它不需要任何编程基础,也不需要懂计算机知识,只要你对编程感兴趣,希望通过自己编写一些简单的程序来处理重复性的工作任务,就可以学。今天这个任务是,实现清理文件工具,能实批量处理文件,批量重命名文件、自动...

收藏 | 20个Pycharm最实用最高效的快捷键(动态展示)

大家好,我是【Python当打之年】本期为大家带来20个Pycharm非常实用的快捷键,希望对你有所帮助。01、Ctrl+/快速注释,如果已经是注释语句,执行后为取消注释,也可以选中代码块(多行...

Python文件、文件夹删除之os、shutil

20221219星期一:方式一:shutil.rmtree(path),暴力删除,直接删除文件夹,不管是否为空方式二:os.remove(),os.rmdir(),保留最外层文件夹方式三:os.rem...

第四课:Python运算符大全与pycharm常用快捷键合集

pycharm中常用的快捷键1.Ctrl+c复制2.Ctrl+v粘贴3.Ctrl+d直接将本行复制粘贴至下一行4.Ctrl+/(?)注释(被注释的代码将无法被运行,跟被删掉差不多,但代码依然保...

HTTPS性能困局:TLS 1.3是加速器还是绊脚石?

一、21%加载延迟背后的真相2024年某第三方测试数据显示,部分移动端设备在启用TLS1.3后页面加载时间增加21%,这一结论引发业界对HTTPS性能的重新审视。但深入分析发现,该数据源于特定场景:...

爬虫中的那些反爬虫措施以及解决方法

本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理1、UserAgentUserAgent的设置能使服务器能够识别客户使用的操作系统及版本、CPU...

Web性能的计算方式与优化方案(二)

通过前面《Web性能的计算方式与优化方案(一)》几个小节的学习,我们了解到如果我们想最终在浏览器显示我们所期望的页面和交互效果,那我们首先需要的是我们应用代码、资源、脚本一切准备好,才后续页面的渲染和...

APP测试过程中Proxifier代理方法_app检测代理,如果突破

0x01Proxifier代理介绍1.1**首先介绍下Proxifier:**Proxifier是一款功能非常强大的代理客户端,支持WindowsXP/Vista/Win7/Win10和M...

python爬虫09 | 上来,自己动!这就是 selenium 的牛逼之处

作为一个男人在最高光的时刻就是说出那句之后还不会被人打...虽然在现实生活中你无法这样但是在这里就让你体验一番那种呼风唤雨的感觉我们之前在爬取某些网站的时候使用到了一些python的请求库模拟浏览...

用ChatGPT高效学习:7天入门Python网络爬虫

用ChatGPT高效学习:7天入门Python网络爬虫以前不懂编程,但经常要从互联网上批量下载一些文件图片视频、收集整理数据等,手工操作耗时耗力。用ChatGPT入门了Python编程后,就寻思着可以...

一文看懂WebRTC建连过程_webrtc断线重连

WebRTC(WebReal-TimeCommunications)是Google公司开源的一项实时通讯技术,它允许网络应用或者站点,在不借助中间媒介的情况下,建立浏览器之间点对点(Peer-to...