详细分析Mysql常用函数(附Demo)

news2024/12/25 13:56:32

目录

  • 前言
  • 1. 聚合函数
  • 2. 字符串函数
  • 3. 日期函数
  • 4. 条件函数
  • 5. 数值函数
  • 6. 类型转换函数

前言

由于实战中经常运用,索性来一个总结文

创建一个名为 employees 的表,包含以下字段:

employee_id:员工ID,整数类型
first_name:员工名,字符串类型
last_name:员工姓,字符串类型
salary:工资,整数类型
hire_date:入职日期,日期类型

具体创建表格内容:

CREATE TABLE employees (
    employee_id INT,
    first_name VARCHAR(50),
    last_name VARCHAR(50),
    salary INT,
    hire_date DATE
);

数据内容:

INSERT INTO employees (employee_id, first_name, last_name, salary, hire_date) VALUES
(1, 'Alice', 'Smith', 60000, '2020-03-15'),
(2, 'Bob', 'Johnson', 75000, '2019-07-20'),
(3, 'Charlie', 'Brown', 50000, '2021-01-10'),
(4, 'David', 'Lee', 80000, '2018-11-05'),
(5, 'Emma', 'Garcia', 55000, '2022-05-28');

1. 聚合函数

以下函数比较简单,就不放结果图了

  • COUNT():计算行数或非空值的数量
    SELECT COUNT(*) AS total_employees FROM employees;
  • SUM():计算指定列的总和
    SELECT SUM(salary) AS total_salary FROM employees;
  • AVG():计算指定列的平均值
    SELECT AVG(salary) AS average_salary FROM employees;
  • MIN():找到指定列的最小值
    SELECT MIN(salary) AS min_salary FROM employees;
  • MAX():找到指定列的最大值
    SELECT MAX(salary) AS max_salary FROM employees;

2. 字符串函数

  • CONCAT():连接两个或多个字符串
    SELECT CONCAT(first_name, ' ', last_name) AS full_name FROM employees;
    在这里插入图片描述

  • SUBSTRING():从字符串中提取子字符串
    SELECT SUBSTRING(first_name, 1, 2) AS initials FROM employees;
    在这里插入图片描述

  • LENGTH():计算字符串的长度
    SELECT first_name, LENGTH(first_name) AS name_length FROM employees;
    在这里插入图片描述

  • UPPER():将字符串转换为大写
    SELECT UPPER(last_name) AS last_name_upper FROM employees;
    在这里插入图片描述

  • LOWER():将字符串转换为小写
    SELECT LOWER(first_name) AS first_name_lower FROM employees;
    在这里插入图片描述

  • TRIM():去除字符串两端的空格
    SELECT TRIM(last_name) AS last_name_trimmed FROM employees;
    在这里插入图片描述

  • REPLACE():替换字符串中的子字符串
    SELECT REPLACE(first_name, 'a', 'A') AS replaced_name FROM employees;
    在这里插入图片描述

3. 日期函数

  • NOW():返回当前日期和时间

  • SELECT NOW() AS current_datetime;

  • DATE():从日期时间值中提取日期部分
    SELECT hire_date, DATE(hire_date) AS hire_date_only FROM employees;
    在这里插入图片描述

  • YEAR():从日期中提取年份
    SELECT hire_date, YEAR(hire_date) AS hire_year FROM employees;

  • MONTH():从日期中提取月份
    SELECT hire_date, MONTH(hire_date) AS hire_month FROM employees;

  • DAY():从日期中提取天数
    SELECT hire_date, DAY(hire_date) AS hire_day FROM employees;

  • DATEDIFF():计算两个日期之间的天数差异
    SELECT hire_date, DATEDIFF(NOW(), hire_date) AS days_since_hire FROM employees;
    在这里插入图片描述

4. 条件函数

  • case结构:
SELECT
    employee_id,
    first_name,
    last_name,
    salary,
    CASE
        WHEN salary < 1000 THEN 'A'
        WHEN salary < 2000 THEN 'B'
        WHEN salary < 3000 THEN 'C'
        ELSE 'D'
    END AS salary_level
FROM employees;

截图如下:

在这里插入图片描述

  • if结构如下:
SELECT
    employee_id,
    first_name,
    last_name,
    salary,
    IF(salary < 60000, '需要关注', '正常') AS status
FROM employees;

截图如下:

在这里插入图片描述

5. 数值函数

  • ROUND():四舍五入到指定的小数位数
SELECT
    employee_id,
    first_name,
    last_name,
    salary,
    ROUND(salary) AS rounded_salary
FROM employees;
  • ABS():返回数的绝对值
SELECT
    employee_id,
    first_name,
    last_name,
    salary,
    ABS(salary) AS absolute_salary
FROM employees;
  • SQRT():返回数的平方根
SELECT
    employee_id,
    first_name,
    last_name,
    salary,
    SQRT(salary) AS sqrt_salary
FROM employees;

以上三个执行代码,数据都一样,截图如下:

在这里插入图片描述

6. 类型转换函数

CAST():将一个数据类型转换为另一个数据类型

(证书转换为浮点数,此处使用DECIMAL不是FLOAT)

SELECT
    employee_id,
    first_name,
    last_name,
    salary,
    CAST(salary AS DECIMAL) AS salary_decimal
FROM employees;

截图如下:

在这里插入图片描述

其他函数:
IFNULL():如果表达式为 NULL,则返回替代值

SELECT
    employee_id,
    first_name,
    IFNULL(last_name, 'Unknown') AS last_name_fixed,
    salary,
    hire_date
FROM employees;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1606718.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

张大哥笔记:0成本创业的小吃配方项目

作为一个在互联网行业沉浸了10年的创业老兵&#xff0c;我最深的体会就是&#xff1a;想要快速赚钱&#xff0c;就要去做与钱密切相关的项目&#xff0c;而最接近金钱的就是贩卖赚钱的机会。那么我们应该赚谁的钱呢&#xff1f;答案是赚那些想要赚钱的人的钱。 近日我刷到了一…

使用python-can和cantools实现arxml报文解析、发送和接收的完整指南

文章目录 背景一、硬件支持二、环境准备1、python解释器安装2、python库安装 三、 收发案例四、 方法拓展1、canoe硬件调用2、回调函数介绍 结论 背景 在汽车行业中&#xff0c;CAN (Controller Area Network) 总线是用于车辆内部通信的关键技术。arxml文件是一种用于描述CAN消…

【JAVA进阶篇教学】第三篇:JDK8中Stream API使用

博主打算从0-1讲解下java进阶篇教学&#xff0c;今天教学第三篇&#xff1a;JDK8中Stream API使用。 Java 8 中的 Stream API 提供了一种便捷、高效的方式来处理集合数据&#xff0c;它支持函数式编程风格的操作&#xff0c;包括过滤、映射、归约等。Stream API 可以大大简化集…

Docker容器逃逸-特权模式-危险挂载-Procfs

Docker容器逃逸-特权模式-危险挂载 Docker这个概念&#xff1a; Docker 容器与虚拟机类似&#xff0c;但二者在原理上不同&#xff0c;容器是将操作系统层虚拟化&#xff0c;虚拟机则是虚拟化硬件&#xff0c;因此容器更具有便携性、高效地利用服务器。 ‍ Docker会遇到的安…

C++学习————第七天(初始化列表、static,友元,内部类)

今天已经是C学习第七天&#xff0c;希望这篇文章能够给大家带来更多的帮助&#xff0c;相应文章都放在C学习专栏里面。 C学习————第五天&#xff08;构造函数 析构函数 拷贝构造函数&#xff09;-CSDN博客 C学习————第六天 &#xff08;运算符重载 const成员 取地址&…

记一次webshell排查但又无webshell的应急

某次应急中&#xff0c;客户吓坏了&#xff0c;说是内网流量分析设备中有很多webshell连接告警&#xff0c;作为一名卑微但又不失理想的安服仔&#xff0c;毅然直奔前线… 过程 去到现场后&#xff0c;直接打开客户的流量分析设备&#xff0c;的确看到一堆冒红的webshell连接…

【Python系列】.env文件

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

单节锂离子/锂聚合物电池保护IC SDG3JX

SDG3JX内置高精度电压检测电路和延迟电路&#xff0c;适用于锂离子/锂聚合物可充电电池的保护IC。SDG3JX 最适合于对单节锂离子/锂聚合物可充电电池组的过充电、过放电和过电流的保护。 特点  内置高精度电压检测电路 * 过充电检测电压:4.28V0.025V&#xff1b; * 过充电解除…

通过 Function Calling 构建自主 AI Agents

原文地址&#xff1a;Build Autonomous AI Agents with Function Calling 将聊天机器人转变为可以与外部 API 交互的代理 2024 年 4 月 2 日 Function Call&#xff08;函数调用&#xff09;并不是什么新鲜事。2023 年 7 月&#xff0c;OpenAI 为其 GPT 模型引入了函数调用&…

环境多介质逸度模型实践技术与典型案例【代码】

随着污染物在各种环境中的迁移和转化&#xff0c;多介质污染物模型日益受到关注。在各类多介质模型中&#xff0c;基于逸度概念的逸度模型由于运用范围广&#xff0c;建模数据要求较低而广受欢迎。 专题一&#xff1a;基本理论 1.逸度的定义 2.逸度模型的基本原理 3.各介质…

rocketmq-dashboard打包测试报错

rocketmq-dashboard运行的时候没问题&#xff0c;但是打包执行测试的时候就是报错 这时候跳过测试就可以成功 报错为 There are test failures. Please refer to D:\CodeEn\rocketmq-dashboard\target\surefire-reports for the individual test results. 你只需要跳过测试就…

Ubuntu22.04.4 - 网络配置 - 笔记

一、设置固定ip 1、cd /etc/netplan 查看文件夹下的配置文件 我这里叫 00-installer-config.yaml 2、sudo nano /etc/netplan/00-installer-config.yaml 完成配置后&#xff0c;按下Ctrl O保存更改&#xff0c;然后按下Ctrl X退出nano编辑器。 3、sudo netplan apply 4、ip …

构建现代网页的引擎:WebKit架构揭秘

在网络信息迅猛增长的今天&#xff0c;浏览器已经成为我们接触世界的重要窗口。而在浏览器的核心&#xff0c;有一个强大的引擎在默默地支撑着网页的渲染和执行&#xff0c;这就是WebKit。 WebKit的核心组件 WebKit作为开源浏览器引擎&#xff0c;由苹果公司发展而来&#x…

使用Python脚本检测服务器信息并定时发送至管理员邮箱

在日常的系统管理工作中&#xff0c;监测服务器的资源占用情况至关重要&#xff0c;我们需要及时获得通知以便采取相应措施。我新装了一台UbuntuServer服务器&#xff0c;写了一个可以定期收集服务器的CPU、内存、网络和磁盘信息&#xff0c;并通过邮件将这些信息发送给管理员的…

万字总结!Docker简介及底层关键技术剖析

本文首发在个人博客上&#xff1a;万字总结&#xff01;Docker简介及底层关键技术剖析 Docker 简介 Docker 是一个开源的应用容器引擎&#xff0c;基于 Go 语言 并遵从 Apache2.0 协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中&#x…

OpenHarmony网络请求库-httpclient

简介 HTTP是现代应用程序通过网络交换数据和媒体的的主要方式。httpclient是OpenHarmony 里一个高效执行的HTTP客户端&#xff0c;使用它可使您的内容加载更快&#xff0c;并节省您的流量。httpclient以人们耳熟能详的OKHTTP为基础&#xff0c;整合android-async-http&#xf…

【SQL每日一练】分组过滤练习题

文章目录 前言MySQL语法注意&#xff1a; 前言 题目&#xff1a;现在运营想查看每个学校用户的平均发贴和回帖情况&#xff0c;寻找低活跃度学校进行重点运营&#xff0c;请取出平均发贴数低于5的学校或平均回帖数小于20的学校。 drop table if exists user_profile; CREATE …

用exe4j将jar包打包成exe可执行文件

首先,可以通过百度网盘下载安装exe4j: 链接:https://pan.baidu.com/s/1YmfVwor2ZDmDi-sDqNUsBw?pwd=a2sq 提取码:a2sq 安装好之后打开exe4j,我这里之前做过配置了已经有配置文件,就一步步截图 定义exe文件名与输出目录 输出日志:

CTFHub(web SQL注入)

CTFHub技能树 Web-SQL注入 详解_666c6167-CSDN博客 Ctfhub - web -- SQL注入_ctfhub sql注入-CSDN博客 整数型注入 方法一 根据提示输入1&#xff0c; 闭合方式就是 1 &#xff0c;整数型 存在两列&#xff0c;这里已经给出了字段&#xff0c;不需要再order by了 爆出数据库…

彻底解决:IDEA java: 警告: 源发行版 17 需要目标发行版 17

一、出现的原因 JDK版本不匹配 二、解决方法 1.点击File -->Project Structure-->Project 修改这两处 2.在Project Structure-->Modules中的红框位置都要调整对应版本 3.点击File-->settings-->java compile将对应框的版本修改成对应版本即可 4.修改Pom文件中…