SQL 入门 10:SQL 内置函数:数值、字符串与时间处理

以下为 SQL 中内置函数的用法解析,涵盖数值、字符串和时间函数。

学习内容

  1. 数值函数
  • ROUND(number, decimals):四舍五入,指定小数位。
  • TRUNCATE(number, decimals):截断至指定小数位,不四舍五入。
  • CEILING(number) / CEIL(number):向上取整。
  • FLOOR(number):向下取整。
  • ABS(number):绝对值。
  • RAND():生成 0 到 <1 的随机浮点数。

常见的数值函数

  1. 字符串函数
  • LENGTH(str):返回字符串长度。
  • UPPER(str) / LOWER(str):转换大小写。
  • LTRIM(str) / RTRIM(str) / TRIM(str):去除左侧、右侧或两侧空格。
  • LEFT(str, n) / RIGHT(str, n):取左或右 n 个字符(含空格)。
  • SUBSTRING(str, start, length):截取字符串,length 可选。
  • LOCATE(substr, str):返回子串首次出现位置(从 1 计数)。
  • REPLACE(str, from_str, to_str):替换所有 from_str 为 to_str。
  • CONCAT(str1, str2, ...):连接字符串。
  • CONCAT_WS(separator, str1, str2, ...):用分隔符连接,跳过 NULL。

常见的字符串函数

  1. 时间函数

常见的unit

  • NOW():当前日期时间。
  • CURDATE():当前日期。
  • CURTIME():当前时间。
  • YEAR(date) / MONTH(date) / DAY(date) / HOUR(time) / MINUTE(time) / SECOND(time):提取对应部分。
  • DAYNAME(date):星期名称。
  • DAYOFMONTH(date):月内第几天。
  • DAYOFWEEK(date):周内第几天(西方周日为 1,东方规则不同)。
  • DAYOFYEAR(date):年内第几天。
  • EXTRACT(unit FROM date):提取指定部分(如 DAY、YEAR)

常见的unit

示例代码与讲解

1. 数值函数

SELECT ROUND(4.78);

  • 四舍五入到 5。

SELECT ROUND(4.987, 2);

  • 四舍五入到 4.99。

SELECT TRUNCATE(4.87235, 3);

  • 截断到 4.872。

SELECT CEILING(46.7);

  • 向上取整到 47。

SELECT FLOOR(46.7);

  • 向下取整到 46。

SELECT ABS(-92.3);

  • 返回 92.3。

SELECT RAND();

  • 生成 0 到 <1 的随机数。

2. 字符串函数

SELECT LENGTH('STEPHEN');

  • 返回 7。

SELECT UPPER('shaun');

  • 转换为 'SHAUN'。

SELECT LOWER('LIVINGSTON');

  • 转换为 'livingston'。

SELECT LTRIM(' KLAY');

  • 去除左侧空格,返回 'KLAY'。

SELECT RTRIM('Green ');

  • 去除右侧空格,返回 'Green'。

SELECT TRIM(' ANDER IGUODALA ');

  • 去除两侧空格,返回 'ANDER IGUODALA'。

SELECT LEFT(' DANTE', 3);

  • 取左 3 字符,返回 ' DA'。

SELECT RIGHT(' DANTE', 3);

  • 取右 3 字符,返回 'NTE'。

SELECT SUBSTRING('JONATHON', 2, 5);

  • 从第 2 位截取 5 字符,返回 'ONATH'。

SELECT LOCATE('S', 'MOSES');

  • 返回 'S' 在 'MOSES' 中首次位置 3。

SELECT REPLACE('ABCDFEG', 'FE', 'EF');

  • 返回 'ABCDEFG'。

SELECT CONCAT(first_name, last_name)

FROM customers;

  • 连接名字,无空格,如 'JohnSmith'。

SELECT CONCAT_WS(' ', first_name, last_name)

FROM customers;

  • 用空格连接,返回 'John Smith'。

SELECT CONCAT(first_name, ' ', last_name)

FROM customers;

  • 同上,灵活性较低。

3. 时间函数

SELECT NOW(), CURDATE(), CURTIME();

  • 示例输出:'2025-04-11 15:02:23', '2025-04-11', '15:02:23'。

SELECT YEAR(NOW()), MONTH(NOW()), DAY(NOW()), HOUR(NOW()), MINUTE(NOW()), SECOND(NOW());

  • 提取当前时间部分,如 2025, 4, 11, 15, 2, 23。

SELECT DAYNAME(NOW()), DAYOFMONTH(NOW()), DAYOFWEEK(NOW()), DAYOFYEAR(NOW());

  • 返回星期名、月内天、周内天(西方周日为 1)、年内天。
  • 注意:DAYOFWEEK 西方规则与东方不同。

SELECT EXTRACT(DAY FROM NOW());

  • 提取当前日期的天,如 11。

作业

1. 时间函数

SELECT *

FROM orders

WHERE EXTRACT(YEAR FROM order_date) = YEAR(NOW());

  • 筛选当前年份(2025)的订单。

总结

本次解析了数值函数(ROUND、TRUNCATE 等)、字符串函数(CONCAT_WS、TRIM 等)和时间函数(NOW、EXTRACT 等)。基于 sql_store 数据库。后续将探讨条件逻辑与格式化。

相关推荐
dLYG DUMS4 分钟前
DBeaver连接本地MySQL、创建数据库表的基础操作
数据库·mysql
李伟_Li慢慢9 分钟前
ShaderToy-山峦+蓝天+白云
前端·webgl
小码哥_常20 分钟前
Android字体字重设置全攻略:XML黑科技+Kotlin动态实现,告别.ttf臃肿
前端
kumat1 小时前
分享-搭建个人系统 MySelfSys
sql·系统
苍煜1 小时前
MySQL分库分表和ES到底怎么选?
数据库·mysql·elasticsearch
茉莉玫瑰花茶1 小时前
Qt 信号与槽 [ 1 ]
开发语言·数据库·qt
czlczl200209251 小时前
松散索引扫描/跳跃索引扫描
数据库·mysql·性能优化
言萧凡_CookieBoty2 小时前
AI 编程省 Token 实战:从 Spec、上下文工程到模型分层的降本策略
前端·ai编程
DFT计算杂谈2 小时前
wannier90 参数详解大全
java·前端·css·html·css3
星马梦缘3 小时前
数据库作战记录 实验7、8
数据库·sql·oracle