当前位置: 首页 > article >正文

【MySQL成神之路】MySQL函数总结

以下是MySQL函数的全面总结,包含概念说明和代码示例:

一、MySQL函数分类

1. 字符串函数
-- CONCAT:连接字符串 
SELECT CONCAT('Hello', ' ', 'World'); 
-- 输出 'Hello World' 
-- SUBSTRING:截取子串 
SELECT SUBSTRING('MySQL', 2, 3); 
-- 输出 'ySQ' 
-- UPPER/LOWER:大小写转换 
SELECT UPPER('mysql'), LOWER('SQL'); 
-- 输出 'MYSQL', 'sql' 
-- TRIM:去除首尾空格SELECT TRIM(' MySQL '); 
-- 输出 'MySQL' 
-- REPLACE:替换字符串 
SELECT REPLACE('Hello World', 'World', 'MySQL'); 
-- 输出 'Hello MySQL' 
2. 数值函数
-- ROUND:四舍五入 
SELECT ROUND(3.1415, 2); 
-- 输出 3.14 
-- ABS:绝对值 
SELECT ABS(-15); 
-- 输出 15 
-- MOD:取余 
SELECT MOD(10, 3); 
-- 输出 1 
-- CEIL/FLOOR:向上/向下取整 
SELECT CEIL(2.3), FLOOR(2.7); 
-- 输出 3, 2 
3. 日期时间函数
-- NOW:当前日期时间 
SELECT NOW(); 
-- 输出 '2023-10-25 14:30:00' 
-- CURDATE/CURTIME:当前日期/时间 
SELECT CURDATE(), CURTIME(); 
-- 输出 '2023-10-25', '14:30:00' 
-- DATE_FORMAT:格式化日期 
SELECT DATE_FORMAT(NOW(), '%Y-%m-%d'); 
-- 输出 '2023-10-25' 
-- DATEDIFF:日期差值 
SELECT DATEDIFF('2023-10-31', '2023-10-25'); 
-- 输出 6 
4. 聚合函数
-- SUM/AVG:求和/平均值 
SELECT SUM(salary), AVG(age) FROM employees; 
-- COUNT:计数 
SELECT COUNT(*) FROM orders WHERE status='completed'; 
-- MAX/MIN:最大/最小值SELECT MAX(price), MIN(quantity) FROM products; 
5. 流程控制函数
-- IF:条件判断 
SELECT IF(score >= 60, 'Pass', 'Fail') AS result FROM exams; 
-- CASE:多条件分支 
SELECT CASE WHEN temperature > 30 THEN 'Hot' WHEN temperature > 20 THEN 'Warm' ELSE 'Cool' END AS weather FROM sensors; 
6. 系统信息函数
-- VERSION:数据库版本 
SELECT VERSION(); 
-- USER:当前用户 
SELECT USER(); 
-- DATABASE:当前数据库 
SELECT DATABASE(); 
7. 加密函数
-- MD5:生成MD5哈希 
SELECT MD5('password123'); 
-- SHA1:生成SHA1哈希 
SELECT SHA1('secret'); 

二、函数使用注意事项


  1. NULL处理

    • 多数函数遇到NULL参数会返回NULL
    • 使用IFNULL处理NULL值
      SELECT IFNULL(email, 'N/A') FROM users; 
  2. 性能优化

    • 避免在WHERE子句中对字段使用函数(会导致索引失效)
    -- 不推荐: 
    SELECT * FROM logs WHERE DATE_FORMAT(created_at, '%Y-%m') = '2025-05'; 
    -- 推荐: 
    SELECT * FROM logs WHERE created_at BETWEEN '2023-10-01' AND '2025-05-31'; 
  3. 可移植性

    • MySQL特有函数(如DATE_FORMAT)在其他数据库可能不兼容

三、综合示例

-- 统计每月销售总额(使用日期函数和聚合函数) 
SELECT DATE_FORMAT(order_date, '%Y-%m') AS month, SUM(amount) AS total_sales FROM orders GROUP BY month ORDER BY month; -- 用户信息格式化(字符串函数嵌套) 
SELECT CONCAT(UPPER(last_name), ', ', first_name) AS full_name, YEAR(birthdate) AS birth_year FROM users WHERE DATEDIFF(CURDATE(), birthdate)/365 > 18; 
-- 筛选成年用户 

四、总结

MySQL函数体系提供了强大的数据处理能力,覆盖字符串操作、数值计算、日期处理、逻辑控制等场景。使用时需注意:

  • 合理选择函数类型和参数
  • 关注NULL值的处理逻辑
  • 在性能敏感场景谨慎使用函数
  • 注意不同数据库系统的函数差异

掌握这些函数的使用方法,可以显著提升SQL查询的灵活性和数据处理效率。

http://www.lryc.cn/news/2386173.html

相关文章:

  • 线程池实战——数据库连接池
  • 修改 vue-pdf 源码升级 pdfjs-dist 包, 以解决部分 pdf 文件显示花屏问题
  • 基于moonshot模型的Dify大语言模型应用开发核心场景
  • 华为OD机试真题——字符串序列判定(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
  • 在Java的list.forEach(即 Stream API 的 forEach 方法)中,无法直接使用 continue 或 break 语句的解决办法
  • Java面向对象高级学习笔记
  • LLM之Agent:Mem0的简介、安装和使用方法、案例应用之详细攻略
  • 工商总局可视化模版-Echarts的纯HTML源码
  • Spring AI 和 Elasticsearch 作为你的向量数据库
  • 阿里云OSS Api工具类不使用sdk
  • 集群聊天服务器学习 配置开发环境(VScode远程连接虚拟机Linux开发)(2)
  • rabbitmq的使用介绍
  • 前端的core-js是什么?有什么作用?
  • 【Python 命名元祖】collections.namedtuple 学习指南
  • 系统编程day04
  • java 加密算法的简单使用
  • Arduino Uno KY-037声音传感器实验
  • 机器学习---各算法比较
  • 基于音频Transformer与动作单元的多模态情绪识别算法设计与实现(在RAVDESS数据集上的应用)
  • Flink SQL 计算实时指标同比的实现方法
  • 什么是VR实景?有哪些高价值场景?
  • 基于MATLAB实现传统谱减法以及两种改进的谱减法(增益函数谱减法、多带谱减法)的语音增强
  • 同一无线网络下的设备IP地址是否相同?
  • 第2周 PINN核心技术揭秘: 如何用神经网络求解偏微分方程
  • 【C语言】习题练手套餐 2
  • [项目总结] 基于Docker与Nginx对项目进行部署
  • 神经正切核推导(2)
  • Python模型优化技巧
  • Redis 面试场景
  • MySQL 索引失效及其解决办法