【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)

前言

大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎! 本章主要内容面向接触过C++ Linux的老铁

主要内容含:

一.数据库函数的应用场景&常见函数盘点介绍

1.函数基本概念

  • 函数 是指一段可以直接被另一段程序调用的程序或代码。
  • 我们通常借助mysql的 内部自带函数 来计算

2.常见函数一览

  • 如下所示

3.数据库函数的应用场景

  • 如下所示

二.字符串函数

1.字符串函数盘点&语法

  • 如下所示
SELECT函数(参数);


2.调用字符串函数案例cv语句&substring注意点

-- concat
select concat('Hello' , ' NySQL');

-- lower
select Lower('HelLo');

-- upper
select upper('Hello');

-- lpad
select lpad('01', 5, '-');

-- rpad
select rpad('01', 5,'-');

- substring
- select substring('Hello NysQL',1,5); //注意索引号从1开始

substring注意点:

  • 注意索引号从1开始

3.调用字符串函数效果演示

  • 效果一览

4.需求练习

--1.由于业务需求变更,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0。比如:1号员工的工号应该为00001。
update emp set workno = Lpad(workno, 5,1 '0');

三.数值函数

1.数值函数盘点

  • 如下所示:

2.调用数值函数案例cv语句

-- ceil
select ceil(1.1);

-- floor
select floor(1.9);

-- mod
select mod(3,4);

-- rand
select rand();

-- round
select round(2.34,2);

3.调用数值函数效果演示

  • 如下所示

4.需求练习

--1.通过数据库的函数,生成一个六位数的随机验证码
select round(rand()*1000000 , 0);
-- 我们一开始可能会这样编写,但会出现5位数情况;随机数介于0-1之间,可能0.019255
-- 我们要补0到6位数

-- 改善后 (左补0)
select Lpad(round(rand()*1000000, 0), 6, '0');

四.日期函数

1.日期函数盘点

  • 如下所示:

2.调用日期函数案例cv语句

--日期函数
-- curdate()
select curdate();

-- curtime()
select curtime();

-- now()
select now();

-- 年月日
seLect YEAR(now());

select MONTH(now());

select DAY(now());

-- 加/减日期
-- date_add
select date_add(now(), INTERVAL 70 YEAR );

-- datediff
select datediff('2021-12-01', '2021-11-01');

3.需求练习

案例:查询所有员工的入职天数,并根据入职天数倒序排序
select name, datediff(curdate(), entrydate) as 'entrydays' from emp order by entrydays desd;

五.流程控制函数

1.流程控制函数盘点

  • 如下所示

2.调用流程控制函数演示&“空串也算串”注意事项

--流程控制函数
-- if
select if(false,'Ok','Error');

-- ifnull
select ifnull('Ok','Default');

select ifnull('','Default');

select ifnull(null,'Default');
  • “空串也算串”注意事项 :
  • select ifnull('','Default');返回结果
  • select ifnull(null,'Default');返回结果

3.需求练习1

-- case when then else end
--需求:查询emp表的员工姓名和工作地址(北京/上海---->一线城市,其他---->二线城市)
select
    name,
    case workaddress when'北京'then'一线城市'when'上海'then'一线城市'else'二线城市'end
from emp;

-- 取别名
select
    name,
    (case workaddress when'北京'then‘一线城市'when‘上海'then'一线城市'else‘二线城市'end)as‘工作地址'
    from emp;

4.需求练习2

1.环境植入

  • 如下所示我们先植入环境
create table score(
       id int comment 'ID',
       name varchar(20)comment'姓名',
       math int comment'数学',
       english int comment'英语',
       chinese int comment'语文'
)comment'学员成续表';
insert into score(id, name, math, english, chinese) VALUES (1, 'Tom', 67, 88, 95 ), (2, 'Rose' , 23, 66, 99),(3, 'Jack',56,98,76);

2.需求练习正文

  • 我们要将成绩换算成
  1. 大于85分"优秀"
  2. 大于60分小于85分"及格"
  3. 小于60分"不及格"
select
   id,
   name,
   (case when math >=85 then'优秀'when math >=60 then'及格'else'不及格'end)'数学',
   (case when english>= 85 then'优秀'when english >=60 then'及格'else'不及格'end)'英语',
   (case when chinese >=85 then'优秀'when chinese >=60 then'及格'else'不及格'end)'语文'
from score;

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
14天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
92 15
|
7天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
14天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
18天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
26天前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
1月前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
39 1
|
1月前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
56 4
|
2月前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
72 3
Mysql(4)—数据库索引
|
1月前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
257 1
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
142 2