mysql中的函数

MySQL提供了丰富的内置函数,涵盖了字符串操作、数字计算、日期和时间处理、条件判断、聚合计算等多个方面。这些函数可以帮助开发者在查询和数据处理时更高效地完成任务。下面是对MySQL中常见的函数分类及其主要函数的介绍:

字符串函数

  1. CONCAT():连接字符串

    sql 复制代码
    SELECT CONCAT('Hello, ', 'world!'); -- 输出: 'Hello, world!'
  2. SUBSTRING() / SUBSTR():截取子字符串

    sql 复制代码
    SELECT SUBSTRING('Hello, world!', 8, 5); -- 输出: 'world'
  3. LENGTH():获取字符串长度

    sql 复制代码
    SELECT LENGTH('Hello'); -- 输出: 5
  4. UPPER():将字符串转换为大写

    sql 复制代码
    SELECT UPPER('hello'); -- 输出: 'HELLO'
  5. LOWER():将字符串转换为小写

    sql 复制代码
    SELECT LOWER('HELLO'); -- 输出: 'hello'
  6. TRIM():去除字符串首尾的空格

    sql 复制代码
    SELECT TRIM('  Hello  '); -- 输出: 'Hello'
  7. REPLACE():替换字符串中的子字符串

    sql 复制代码
    SELECT REPLACE('Hello, world!', 'world', 'there'); -- 输出: 'Hello, there!'

数字函数

  1. ABS():取绝对值

    sql 复制代码
    SELECT ABS(-10); -- 输出: 10
  2. CEIL() / CEILING():向上取整

    sql 复制代码
    SELECT CEIL(4.2); -- 输出: 5
  3. FLOOR():向下取整

    sql 复制代码
    SELECT FLOOR(4.8); -- 输出: 4
  4. ROUND():四舍五入

    sql 复制代码
    SELECT ROUND(4.567, 2); -- 输出: 4.57
  5. MOD():取模(取余数)

    sql 复制代码
    SELECT MOD(10, 3); -- 输出: 1
  6. POWER():幂运算

    sql 复制代码
    SELECT POWER(2, 3); -- 输出: 8
  7. SQRT():开平方

    sql 复制代码
    SELECT SQRT(16); -- 输出: 4

日期和时间函数

  1. NOW():当前日期和时间

    sql 复制代码
    SELECT NOW(); -- 输出当前日期和时间
  2. CURDATE():当前日期

    sql 复制代码
    SELECT CURDATE(); -- 输出当前日期
  3. CURTIME():当前时间

    sql 复制代码
    SELECT CURTIME(); -- 输出当前时间
  4. DATE():提取日期部分

    sql 复制代码
    SELECT DATE(NOW()); -- 输出当前日期部分
  5. TIME():提取时间部分

    sql 复制代码
    SELECT TIME(NOW()); -- 输出当前时间部分
  6. DATEDIFF():计算日期差

    sql 复制代码
    SELECT DATEDIFF('2024-12-31', '2024-01-01'); -- 输出: 364
  7. DATE_ADD():日期加上时间间隔

    sql 复制代码
    SELECT DATE_ADD('2024-01-01', INTERVAL 10 DAY); -- 输出: '2024-01-11'
  8. DATE_SUB():日期减去时间间隔

    sql 复制代码
    SELECT DATE_SUB('2024-01-01', INTERVAL 10 DAY); -- 输出: '2023-12-22'

条件函数

  1. IF():条件判断

    sql 复制代码
    SELECT IF(1 > 0, 'true', 'false'); -- 输出: 'true'
  2. IFNULL():判断是否为NULL

    sql 复制代码
    SELECT IFNULL(NULL, 'default'); -- 输出: 'default'
  3. CASE:条件表达式

    sql 复制代码
    SELECT CASE
               WHEN score >= 90 THEN 'A'
               WHEN score >= 80 THEN 'B'
               WHEN score >= 70 THEN 'C'
               ELSE 'F'
           END AS grade
    FROM students;

聚合函数

  1. COUNT():计数

    sql 复制代码
    SELECT COUNT(*) FROM employees; -- 输出员工总数
  2. SUM():求和

    sql 复制代码
    SELECT SUM(salary) FROM employees; -- 输出薪水总和
  3. AVG():平均值

    sql 复制代码
    SELECT AVG(salary) FROM employees; -- 输出平均薪水
  4. MAX():最大值

    sql 复制代码
    SELECT MAX(salary) FROM employees; -- 输出最大薪水
  5. MIN():最小值

    sql 复制代码
    SELECT MIN(salary) FROM employees; -- 输出最小薪水

JSON 函数(从MySQL 5.7开始)

  1. JSON_EXTRACT():提取JSON数据

    sql 复制代码
    SELECT JSON_EXTRACT('{"name": "John", "age": 30}', '$.name'); -- 输出: 'John'
  2. JSON_UNQUOTE():去掉JSON字符串的引号

    sql 复制代码
    SELECT JSON_UNQUOTE(JSON_EXTRACT('{"name": "John"}', '$.name')); -- 输出: John
  3. JSON_OBJECT():创建JSON对象

    sql 复制代码
    SELECT JSON_OBJECT('name', 'John', 'age', 30); -- 输出: {"name": "John", "age": 30}
  4. JSON_ARRAY():创建JSON数组

    sql 复制代码
    SELECT JSON_ARRAY('apple', 'banana', 'cherry'); -- 输出: ["apple", "banana", "cherry"]
  5. JSON_MERGE():合并两个JSON对象

    sql 复制代码
    SELECT JSON_MERGE('{"name": "John"}', '{"age": 30}'); -- 输出: {"name": "John", "age": 30}
相关推荐
倔强的石头_14 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端