Mysql学习笔记之函数

1.简介

SQL提供了很多函数,便于在查询时能够快速的进行计算或者计数等操作,下文介绍一些实际场景中常用的函数。

2.字符串函数

常用的字符串函数如下表所示:

函数名描述
LENGTH(str)返回字符串的长度,以字节为单位。例如LENGTH(‘hello’)返回5
CHAR_LENGTH(str)返回字符串的长度,以字符为单位。对于多字节字符集,一个字符可能占用多个字节
CONCAT(str1,str2,…)将多个字符串str1、str2等连接成一个字符串。例如CONCAT(‘hello’, ’ ', ‘world’)返回“hello world”
SUBSTRING(str, pos, len)从字符串str中返回起始位置为pos、长度为len的子字符串。例如SUBSTRING(‘hello’, 2, 3)返回“ell”
UPPER(str)将字符串str中的所有字符转换为大写
LOWER(str)将字符串str中的所有字符转换为小写
REPLACE(str, from_str, to_str)将字符串str中所有出现的子字符串from_str替换为to_str。例如REPLACE(‘hello world’, ‘world’, ‘mysql’)返回“hello mysql”

3. 数值函数

函数名描述
ABS(num)返回数值num的绝对值。例如ABS(-5)返回5
CEIL(num)向上取整,例如CEIL(3.14)返回4
FLOOR(num)向下取整,例如CEIL(3.14)返回3
ROUND(num, decimals)指定保留几位小数,例如ROUND(3.14159, 2)返回3.14
RAND()返回一个0到1之间的随机浮点数
POW(base, exp)返回base的exp次幂。例如POW(2, 3)返回8

4.日期时间函数

函数名描述
NOW()返回当前的日期和时间,例如NOW()返回“2025-01-12 15:30:00”
CURDATE()返回当前日期,例如CURDATE()返回“2025-01-12”
CURTIME()返回当前时间,例如CURTIME()返回“15:30:00”
DATE_ADD(date, INTERVAL expr type)将时间间隔expr添加到日期date中。type可以是DAY、MONTH、YEAR等。例如DATE_ADD(‘2025-01-12’, INTERVAL 10 DAY)返回“2025-01-22”
DATE_SUB(date, INTERVAL expr type)从日期date中减去时间间隔expr。例如DATE_SUB(‘2025-01-12’, INTERVAL 10 DAY)返回“2024-12-31”
DATEDIFF(expr1, expr2)返回两个日期expr1和expr2之间的天数差。例如DATEDIFF(‘2025-01-22’, ‘2025-01-12’)返回10

5.聚合函数

函数名描述
COUNT(expr)返回expr中非NULL值的数量。常用于统计记录数
SUM(expr)返回expr中所有值的总和。expr通常为数值类型的列。例如SUM(salary)计算工资总和
AVG(expr)返回expr中所有值的平均值。例如AVG(age)计算平均年龄
MAX(expr)返回expr中的最大值。例如MAX(score)获取最高分数
MIN(expr)返回expr中的最小值。例如MIN(price)获取最低价格

6.条件函数

函数名描述
IF(value , t , f)如果value为true,则返回t,否则返回f
IFNULL(value1 , value2)如果value1不为空,返回value1,否则返回value2
CASE WHEN [ val1 ] THEN [res1] … ELSE [ default ] END如果val1为true,返回res1,… 否则返回default默认值
CASE [ expr ] WHEN [ val1 ] THEN [res1] … ELSE [ default ] END如果expr的值等于val1,返回res1,… 否则返回default默认值

case语句语法:

CASE column_nameWHEN value1 THEN result1WHEN value2 THEN result2...ELSE default_result
END
-- 或者
CASE column_nameWHEN value1 THEN result1WHEN value2 THEN result2...ELSE default_result
END

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

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

相关文章

pytest 参数介绍

命令行参数描述常见使用案例-v / --verbose显示每个测试用例的详细信息,包括测试名称和状态pytest -v-s / --captureno禁用输出捕获,允许 print() 输出显示pytest -s-q / --quiet安静模式,减少输出,仅显示每个测试的通过/失败结果…

10步打造完美ASP.NET、Web API和控制台应用程序文件夹结构

一、前言 在大型项目中,合理的文件夹结构是项目成功的关键之一。一个好的文件夹结构就像是一座井然有序的图书馆,每一本书(代码文件)都有其固定的位置,让人能迅速找到所需。它可以让团队成员更容易理解和维护代码&…

conntrack iptables 安全组

centos 安装yum install conntrack-tools 1. conntrack状态 NEW: 新建连接(第一次包)。 ESTABLISHED: 已建立连接,正在传输数据。 RELATED: 与已有连接相关的连接,如 FTP 数据连接。 INVALID: 无效连接,无法识别或不…

相机和激光雷达的外参标定 - 无标定板版本

1. 实现的效果 通过本软件实现求解相机和LiDAR的外参,即2个传感器之间的三维平移[x, y, z]和三维旋转[roll, pitch, yaw]。完成标定后,可将点云投影到图像,效果图如下: 本软件的优势:(1)无需特…

WPF系列九:图形控件EllipseGeometry

简介 EllipseGeometry用于绘制一个椭圆的形状。它通常与其他图形元素结合使用,比如 Path 或者作为剪切区域来定义其他元素的外形。 定义椭圆:EllipseGeometry 用来定义一个椭圆或者圆的几何形状。参与绘制:可以被用作 Path 元素的数据&…

EFCore HasDefaultValueSql (续2 HasComputedColumnSql)

前情:EFCore HasDefaultValueSql EFCore HasDefaultValueSql (续1 ValueGeneratedOnAdd)-CSDN博客 小伙伴在使用 HasDefaultValueSql 时,对相关的 ValueGeneratedOnAdd, HasComputedColumnSql 也有了疑问: HasComputedColumnSql 对于计算…

qt设置qwidget背景色无效

最近在做一个界面,有三个子窗体,于是就把各个子窗体分别做成了三个UI,再将3个UI,放到1个UI,再将那一个UI在其他窗体上进行提升。 最后就发现怎么设置qwidget的背景都没有效果。 在Qt中,如果是给Qwidget的…

【Rust学习笔记】Rust 的所有权介绍

博主未授权任何人或组织机构转载博主任何原创文章,感谢各位对原创的支持! 博主链接 博客内容主要围绕: 5G/6G协议讲解 高级C语言讲解 Rust语言讲解 文章目录 Rust中的所有权介绍1.1 一个简单的例子1.2 一个稍微复杂的例…

Centos9-SSH免密登录配置-修改22端口-关闭密码登录-提高安全性

Centos9-SSH免密登录配置-修改22端口-关闭密码登录 生成秘钥对将公钥信息存进authorized_keys测试登录查询访问记录、比对指纹更换22访问端口关闭账号密码登录生成秘钥对 生成密钥对,指定 备注 和 文件目录命令执行后,默认两次回车,不设置秘钥使用密码ssh-keygen -t rsa -b …

CentOS7下Hadoop集群分布式安装详细图文教程

1、集群规划 主机 角色 DSS20 NameNode DataNode ResourceManager NodeManager DSS21 SecondaryNameNode NameNode NodeManager DSS22 DataNode NodeManager 1.1、环境准备 1.1.1 关闭防火墙 #查看防火墙状态 firewall-cmd --state #停止…

Github 2025-01-11 Rust开源项目日报 Top10

根据Github Trendings的统计,今日(2025-01-11统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Rust项目10C项目1Swift项目1Yazi - 快速终端文件管理器 创建周期:210 天开发语言:Rust协议类型:MIT LicenseStar数量:5668 个Fork数量:122…

在 Vue 项目中使用地区级联选

在 Vue 项目中使用地区级联选择的完整流程: 1.安装依赖包,这个包提供了中国省市区的完整数据。 npm install element-china-area-data --save 2.导入数据 import { regionData } from element-china-area-data 这个包提供了几种不同的数据格式&#…

深入学习 Python 爬虫:从基础到实战

深入学习 Python 爬虫:从基础到实战 前言 Python 爬虫是一个强大的工具,可以帮助你从互联网上抓取各种数据。无论你是数据分析师、机器学习工程师,还是对网络数据感兴趣的开发者,爬虫都是一个非常实用的技能。在本文中&#xff…

npm i 报错

nodejs中 使用npm install命令时报错 npm err! file C: \user\admin\package.json_package.json 里缺少 description 和 repository 两个n字段。-CSDN博客

基于改进粒子群优化的无人机最优能耗路径规划

目录 1. Introduction2. Preliminaries2.1. Particle Swarm Optimization Algorithm2.2. Deep Deterministic Policy Gradient2.3. Calculation of the Total Output Power of the Quadcopter Battery 3.OptimalEnergyConsumptionPathPlanningBasedonPSO-DDPG3.1.ProblemModell…

Redis为 List/Set/Hash 的元素设置单独的过期时间

一.业务简介 我们知道,Redis 里面暂时没有接口给 List、Set 或者 Hash 的 field 单独设置过期时间,只能给整个列表、集合或者 Hash 设置过期时间。 这样,当 List/Set/Hash 过期时,里面的所有 field 元素就全部过期了。但这样并不…

Mysql常见知识点

Mysql是最常用的数据库了。 1、什么是关系型数据库? 关系型数据库(RDB,Relational Database)就是一种建立在关系模型的基础上的数据库。关系模型表明了数据库中所存储的数据之间的联系(一对一、一对多、多对多&#…

【51单片机】03 蜂鸣器-播放音乐

蜂鸣器-播放音乐 一、原理介绍1.硬件电路 二、练习1.让蜂鸣器发声2.尝试演奏小星星 一、原理介绍 蜂鸣器分为有源蜂鸣器、无源蜂鸣器两种。 有源蜂鸣器:施加合适的电压之后就会发出特定频率的声音 无源蜂鸣器:需要提供特定频率的声音信号,才能…

leetcode热题100——NO.206反转链表——JAVA

一、题目描述 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 二、题目分析 双指针操作:prev指针,curr指针; 对单链表的理解:包含属性(成员变量)和方法&#xff1…

30_Redis哨兵模式

在Redis主从复制模式中,因为系统不具备自动恢复的功能,所以当主服务器(master)宕机后,需要手动把一台从服务器(slave)切换为主服务器。在这个过程中,不仅需要人为干预,而且还会造成一段时间内服务器处于不可用状态,同时数据安全性也得不到保障,因此主从模式的可用性…