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

SQL 逻辑处理核心知识点全解析,从入门到精通看这篇就够了!

moboyou 2025-06-04 00:13 17 浏览

刚入行程序员 / 数据分析?写 SQL 总卡壳?别愁!今天一次性把SQL 逻辑处理核心技能讲透,涵盖数值、字符、日期函数 + 条件表达式,附超全数据库差异对比,工作中直接套用!

一、SQL 函数大揭秘!这 4 类核心函数搞定 90% 数据处理难题

(1)数值函数:算工资 / 抽奖 / 取整全靠它

绝对值、取整函数

  • ABS(x) 直接算绝对值,负数变正数超简单
  • 向上取整用CEIL(x)(Oracle/PostgreSQL),SQL Server 用CEILING(x),向下取整FLOOR(x)全库通用 场景:计算员工绩效分(如 0.6 分按 1 分算,直接CEIL(0.6))

随机数函数:抽奖必备!

  • MySQL/SQLite:RAND() 生成 0-1 随机小数,每次调用都不同
  • Oracle:DBMS_RANDOM.VALUE 更强大,还能生成随机字符串
  • SQL Server:注意!同一查询里RAND()返回值相同,得用NEWID()辅助排序

(2)字符函数:处理姓名 / 邮箱 / 地址全靠它

字符串长度

  • 算字符数用CHAR_LENGTH(s)(MySQL/PostgreSQL),Oracle 用LENGTH(s),SQL Server 用LEN(s)
  • 算字节数(存数据库必看!):OCTET_LENGTH(s)(MySQL)、LENGTHB(s)(Oracle)

字符串拼接

  • 通用CONCAT('S','Q','L')直接拼,Oracle 一次只能拼 2 个,得嵌套CONCAT(CONCAT('S','Q'),'L')
  • 带分隔符拼接CONCAT_WS('-','S','Q','L')= S-Q-L,新手必学!

(3)日期函数:算工龄 / 考勤 / 截止日必备

当前时间

  • 查日期CURRENT_DATE、时间CURRENT_TIME,SQL Server 得用CAST(GETDATE() AS DATE)转换

日期加减

  • 算天数差:MySQL 用DATEDIFF('2023-10-01','2023-09-01'),Oracle 直接'2023-10-01'-'2023-09-01'
  • 算月份差:SQL Server 用DATEADD(MONTH,-1,'2023-02-01'),SQLite 靠STRFTIME函数实现

(4)转换函数:避免类型错误!

  • 显式转换CAST("123" AS INTEGER):字符串转数字必用,防止计算出错
  • 隐式转换要小心!"666"+123会自动转数字,但"abc"+123直接报错,新手常踩坑!

二、告别复杂 IF 语句!SQL 条件表达式 CASE 让逻辑处理更简单

(1)简单 CASE:等值判断秒出结果

-- 根据部门编号转部门名称  

SELECT emp_name,

CASE dept_id

WHEN 1 THEN '行政部'

WHEN 2 THEN '人事部'

ELSE '其他部门'

END AS 部门

FROM employee;

适合固定值匹配,比如性别、状态码转换

(2)搜索 CASE:复杂逻辑一步搞定

-- 根据月薪分收入等级  

SELECT emp_name, salary,

CASE

WHEN salary < 10000 THEN '低收入'

WHEN salary < 20000 THEN '中收入'

ELSE '高收入'

END AS 收入级别

FROM employee;

重点!支持范围判断(如薪资区间)、多条件组合(AND/OR),比 Excel 函数强 10 倍!

(3)不同数据库 “平替” 函数

  • Oracle 专属DECODE:功能类似简单 CASE,但移植性差,建议少用
  • MySQL 的IF/SQL Server 的IIF:简化版条件判断,适合新手快速入门

三、3 个实战案例!直接套用解决工作难题

(1)年会抽奖:随机抽 1 人怎么写?

  • MySQL/PostgreSQL:SELECT * FROM employee ORDER BY RAND() LIMIT 1;
  • SQL Server:SELECT * FROM employee ORDER BY NEWID() FETCH FIRST 1 ROW ONLY; 注意!加LIMIT 1/FETCH FIRST才能只返回 1 条,新手常忘!

(2)隐私保护:姓名隐藏中间字(如 “张 * 三”)

-- 适用于3字及以上姓名  

SELECT CONCAT(

LEFT(emp_name, CHAR_LENGTH(emp_name)-2), -- 取前n-2个字

'*', -- 中间用*代替

RIGHT(emp_name, 1) -- 取最后1个字

) AS 隐藏姓名

FROM employee;

(3)算入职年限发礼品:多条件判断怎么写?

-- 按入职年份+性别发礼品  

SELECT emp_name,

CASE

WHEN EXTRACT(YEAR FROM hire_date) > 2011 AND sex='男' THEN '手表'

WHEN EXTRACT(YEAR FROM hire_date) > 2011 AND sex='女' THEN '化妆品'

ELSE '电脑'

END AS 礼品

FROM employee;

四、新手必看!不同数据库函数差异表(直接截图保存)

功能

Oracle

MySQL

SQL Server

PostgreSQL

SQLite

求余数

MOD(x,y)

MOD(x,y)/%

%

MOD(x,y)/%

%

随机数

DBMS_RANDOM

RAND()

RAND ()(需 NEWID)

RANDOM()

RANDOM()

字符串连接

CONCAT(2 参)

CONCAT

+



提取年份

EXTRACT(YEAR)

EXTRACT(YEAR)

DATEPART(YEAR)

EXTRACT(YEAR)

STRFTIME("%Y")

五、写在最后:3 个学习小贴士

  1. 记不住函数? 收藏这篇笔记,按 “数值 / 字符 / 日期 / 条件” 分类查,比翻文档快 10 倍!
  1. 避免踩坑! 不同数据库语法有差异(如 SQL Server 的 ROUND 不能省参数),写完先在本地测试!
  1. 实战最重要! 用员工表 / 订单表练手,比如算每个员工年薪、隐藏身份证号中间 8 位,边练边记印象深!

学会这一套,处理数据效率翻倍,写复杂报表再也不用加班!赶紧转发给需要的同事,一起涨薪升职!#SQL##数据分析师##数据库#

相关推荐

Excel技巧:SHEETSNA函数一键提取所有工作表名称批量生产目录

首先介绍一下此函数:SHEETSNAME函数用于获取工作表的名称,有三个可选参数。语法:=SHEETSNAME([参照区域],[结果方向],[工作表范围])(参照区域,可选。给出参照,只返回参照单元格...

Excel HOUR函数:“小时”提取器_excel+hour函数提取器怎么用

一、函数概述HOUR函数是Excel中用于提取时间值小时部分的日期时间函数,返回0(12:00AM)到23(11:00PM)之间的整数。该函数在时间数据分析、考勤统计、日程安排等场景中应用广泛。语...

Filter+Search信息管理不再难|多条件|模糊查找|Excel函数应用

原创版权所有介绍一个信息管理系统,要求可以实现:多条件、模糊查找,手动输入的内容能去空格。先看效果,如下图动画演示这样的一个效果要怎样实现呢?本文所用函数有Filter和Search。先用filter...

FILTER函数介绍及经典用法12:FILTER+切片器的应用

EXCEL函数技巧:FILTER经典用法12。FILTER+切片器制作筛选按钮。FILTER的函数的经典用法12是用FILTER的函数和切片器制作一个筛选按钮。像左边的原始数据,右边想要制作一...

office办公应用网站推荐_office办公软件大全

以下是针对Office办公应用(Word/Excel/PPT等)的免费学习网站推荐,涵盖官方教程、综合平台及垂直领域资源,适合不同学习需求:一、官方权威资源1.微软Office官方培训...

WPS/Excel职场办公最常用的60个函数大全(含卡片),效率翻倍!

办公最常用的60个函数大全:从入门到精通,效率翻倍!在职场中,WPS/Excel几乎是每个人都离不开的工具,而函数则是其灵魂。掌握常用的函数,不仅能大幅提升工作效率,还能让你在数据处理、报表分析、自动...

收藏|查找神器Xlookup全集|一篇就够|Excel函数|图解教程

原创版权所有全程图解,方便阅读,内容比较多,请先收藏!Xlookup是Vlookup的升级函数,解决了Vlookup的所有缺点,可以完全取代Vlookup,学完本文后你将可以应对所有的查找难题,内容...

批量查询快递总耗时?用Excel这个公式,自动计算揽收到签收天数

批量查询快递总耗时?用Excel这个公式,自动计算揽收到签收天数在电商运营、物流对账等工作中,经常需要统计快递“揽收到签收”的耗时——比如判断某快递公司是否符合“3天内送达”的服务承...

Excel函数公式教程(490个实例详解)

Excel函数公式教程(490个实例详解)管理层的财务人员为什么那么厉害?就是因为他们精通excel技能!财务人员在日常工作中,经常会用到Excel财务函数公式,比如财务报表分析、工资核算、库存管理等...

Excel(WPS表格)Tocol函数应用技巧案例解读,建议收藏备用!

工作中,经常需要从多个单元格区域中提取唯一值,如体育赛事报名信息中提取唯一的参赛者信息等,此时如果复制粘贴然后去重,效率就会很低。如果能合理利用Tocol函数,将会极大地提高工作效率。一、功能及语法结...

Excel中的SCAN函数公式,把计算过程理清,你就会了

Excel新版本里面,除了出现非常好用的xlookup,Filter公式之外,还更新一批自定义函数,可以像写代码一样写公式其中SCAN函数公式,也非常强大,它是一个循环函数,今天来了解这个函数公式的计...

Excel(WPS表格)中多列去重就用Tocol+Unique组合函数,简单高效

在数据的分析和处理中,“去重”一直是绕不开的话题,如果单列去重,可以使用Unique函数完成,如果多列去重,如下图:从数据信息中可以看到,每位参赛者参加了多项运动,如果想知道去重后的参赛者有多少人,该...

Excel(WPS表格)函数Groupby,聚合统计,快速提高效率!

在前期的内容中,我们讲了很多的统计函数,如Sum系列、Average系列、Count系列、Rank系列等等……但如果用一个函数实现类似数据透视表的功能,就必须用Groupby函数,按指定字段进行聚合汇...

Excel新版本,IFS函数公式,太强大了!

我们举一个工作实例,现在需要计算业务员的奖励数据,右边是公司的奖励标准:在新版本的函数公式出来之前,我们需要使用IF函数公式来解决1、IF函数公式IF函数公式由三个参数组成,IF(判断条件,对的时候返...

Excel不用函数公式数据透视表,1秒完成多列项目汇总统计

如何将这里的多组数据进行汇总统计?每组数据当中一列是不同菜品,另一列就是该菜品的销售数量。如何进行汇总统计得到所有的菜品销售数量的求和、技术、平均、最大、最小值等数据?不用函数公式和数据透视表,一秒就...