SQL刷题日志(day2)

1、timestampdiff:计算时间间隔

sql 复制代码
timestampdiff(unit,start_date,end_date)

参数说明:

  • unit:返回的时间单位,如minute,hour等
  • start_date:开始日期
  • end_date:结束日期

2、dense_rank():对数据进行排名

sql 复制代码
dense_rank() over (partition by column order by column)

参数说明:

  • partition by column:可选参数,用于定义如何将结果集划分为不同的组。每个组内的行将独立进行排名。
  • order by column:必需参数,用于定义窗口函数内部的排序规则

!!!与row_number()联系与区别:

联系:

  • 两者都是窗口函数,可以在不改变原始数据集的情况下,为每一行生成一个序号。
  • 都可以使用 OVER() 子句来定义窗口的排序规则和分区。
  • 都可以在查询结果中为每一行生成一个唯一的标识符,用于进一步的分析或操作。

区别:

  • dense_rank():为每一行分配一个排名,如果行的值相同,它们将获得相同的排名
  • row_number():为每一行分配一个唯一的连续整数,即使某些行的值相同,它们的序号也会不同

3、ifnull():为缺失数据赋值

sql 复制代码
ifnull(column_name,0)

参数说明:column_name:若值为null,则置为0

4、coalesce():为缺失数据指定默认值

sql 复制代码
coalesce(column_name,0)--将Null值视为0

5、floor():向下取整

sql 复制代码
floor(number):取小于等于数值number的最小整数(向下取整)
--如:floor(12.45)返回12

拓展:

  • ceiling(number):取大于等于数值n的最小整数(向上取整)
  • round(number):四舍五入到指定的小数位数。如果没有指定小数位数,则默认四舍五入到整数。
  • truncate(number,2):截断数值到指定的小数位数,不进行四舍五入(如truncate(123.456, 2) 返回 123.45(截断到小数点后两位)
  • cast(.. as signed):将数值转换为符号整数
相关推荐
岳麓丹枫00114 小时前
PG数据库无法接受连接问题分析定位
数据库·postgresql
JdSnE27zv15 小时前
SQLite内存数据库
数据库·sql·sqlite
SelectDB技术团队15 小时前
预约发布会|核心产品力首发,如何构建面向 Agent 时代的企业级数据引擎
数据库·数据仓库·人工智能·数据分析·可观测·apache doris·selectdb
2601_9618451515 小时前
2026四级作文预测题|英语四级写作押题+提纲PDF
java·c语言·数据库·c++·python·pdf·php
计算机安禾15 小时前
【数据库系统原理】第13篇:现实世界的概念抽象:实体-联系模型向关系模型的转化策略
数据库
JAVA面经实录91715 小时前
NoSQL 非关系型数据库【简洁版】
java·数据库·nosql
IvorySQL15 小时前
PostgreSQL 19 新特性:基于 SQL/PGQ 实现图数据查询
数据库·sql·postgresql
jghhh0115 小时前
C# 图片水印工具(支持9个位置)
数据库·microsoft·c#
辰海Coding15 小时前
MiniSpring框架学习笔记-JDBC 访问框架:如何抽取 JDBC 模板并隔离数据库?
java·数据库·笔记·学习·spring
救救孩子把15 小时前
01 Milvus-向量数据库基础
数据库·milvus