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

目录

  • 前言
  • 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结构:
SELECTemployee_id,first_name,last_name,salary,CASEWHEN salary < 1000 THEN 'A'WHEN salary < 2000 THEN 'B'WHEN salary < 3000 THEN 'C'ELSE 'D'END AS salary_level
FROM employees;

截图如下:

在这里插入图片描述

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

截图如下:

在这里插入图片描述

5. 数值函数

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

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

在这里插入图片描述

6. 类型转换函数

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

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

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

截图如下:

在这里插入图片描述

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

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

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

动手学大模型LLM应用开发之提示词工程(Prompt Engineering)

目录 一、什么是提示词工程(Prompt Engineering)&#xff1f;二、Prompt 设计的原则及使用技巧原则一&#xff1a;编写清晰、具体的指令1、使用分隔符清晰地表示输入的不同部分2、寻求结构化的输出3、要求模型检查是否满足条件4、提供少量示例 原则二&#xff1a;给模型时间去思…

《Super Simple Skybox》天空盒 -- 创造绝美天空的神奇工具!限时免费!

《Super Simple Skybox》天空盒 -- 创造绝美天空的神奇工具&#xff01;限时免费&#xff01; 前言内容介绍资源特色动态&#xff0c;美丽的天空在几秒钟内即插即用 功能列表领取兑换码 前言 ^^在这个充满创意与想象的世界里&#xff0c;Unity 免费资源犹如一颗璀璨的明珠&…

【创建型模式】原型模式

一、原型模式概述 原型&#xff08;Prototype&#xff09;模式的定义&#xff1a;用一个已经创建的实例作为原型&#xff0c;通过复制该原型对象来创建一个和原型相同或相似的新对象。在这里&#xff0c;原型实例指定了要创建的对象的种类。用这种方式创建对象非常高效&#xf…

Redis的RedisObject和对外可见的5种数据结构

目录 RedisObject Redis的编码方式 对外可见的5种数据结构 1.string string结构的源码 为什么是小于44字节会采用embstr编码&#xff1f; embstr和raw区别 2.list list结构的源码 3.set set结构的源码 4.zset zset结构的源码 5.hash hash结构的源码 Redis中…

yolov7模型输出层预测方法解读

本文从代码的角度分析模型训练阶段输出层的预测包括以下几个方面&#xff1a; 标注数据&#xff08;下文统称targets&#xff09;的正样本分配策略&#xff0c;代码实现位于find_3_positive。候选框的生成&#xff0c;会介绍输出层的预测值、GT、grid、 anchor之间的联系损失函…

Git使用总结(不断更新中)

branch 本地分支操作 删除本地分支 git branch -d <local-branch-name>远端分支操作 从远端分支创建本地分支 git checkout -b <local-branch-name> origin/<remote-branch-name>git ignore 如果工程的代码文件中有不希望上传到远端的文件&#xff0c;…

华为机考入门python3--(16)牛客16-购物单最大满意度

分类&#xff1a;动态规划&#xff0c;组合&#xff0c;最大值&#xff0c;装箱问题 知识点&#xff1a; 生成递减数 100, 90, 80, ..., 0 range(100, -1, -10) 访问列表的下标key for key, value in enumerate(my_list): 动态规划-捆绑装箱问题 a. 把有捆绑约束的物…

jvm中提前进入老年代

在JVM中&#xff0c;对象的“年龄”通常指的是对象经过了多少次Minor GC&#xff08;新生代垃圾回收&#xff09;后仍然存活。每次Minor GC后&#xff0c;存活的对象会被移动到Survivor区&#xff0c;并且它们的年龄会增加。当对象的年龄达到某个阈值&#xff08;这个阈值可以通…

uni-admin中引入uni-cms的缺少schema及uni-media-library缺少云函数的问题

1. 在管理端运行提示一些表找不到&#xff0c;因为是uni-admin关联的uni-starter的服务空间&#xff0c;在uni-admin的uniCloud中没有内容&#xff0c;在uni-starter的uniCloud中也没有发现对应的表&#xff0c;后面干脆在云端找到对应的表之后新建了&#xff0c;然后再下载到本…

Qt/C++音视频开发70-无感切换通道/无缝切换播放视频/多通道流畅切换/不同视频打开无缝切换

一、前言 之前就写过这个方案&#xff0c;当时做的是ffmpeg内核版本&#xff0c;由于ffmpeg内核解析都是代码实现&#xff0c;所以无缝切换非常完美&#xff0c;看不到丝毫的中间切换过程&#xff0c;看起来就像是在一个通道画面中。其实这种切换只能说是取巧办法&#xff0c;…

MySQL 锁机制全面解析

目录 1. MySQL的锁类型1.1 全局锁1.2 表锁1.3 行锁1.4 共享锁&#xff08;读锁&#xff09;1.5 排它锁&#xff08;写锁&#xff09;1.6 死锁 2 乐观锁和悲观锁2.1 乐观锁2.2 悲观锁 3 意向锁4 间隙锁5 临键锁6. 事务隔离级别对锁的影响6.1 读未提交&#xff08;Read Uncommitt…

二分法问题

日升时奋斗&#xff0c;日落时自省 目录 1、二分法 2、二分法问题 2.1 、在排序数组中查找元素的第一个和最后一个位置 2.2、搜索插入位置 2.3、山脉数组的峰顶索引 2.4、0-n-1中缺失的数字 1、二分法 二分法是比较简单的一种查找算法&#xff0c;但是效率很高&#xff0…