Mysql(一) 数据库实现-DDL-DML-DQL及各种函数用法(二)

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: IFNULL函数是MySQL控制流函数之一,它有两个参数,两个参数可以是真实值或表达式,如果expr1不是NULL,则返回第一个参数(expr1)。 否则,IFNULL函数返回第二个参数。

4.13、Sql书写与执行顺序

4.13.1、语法顺序

select

distinct

from

join

on

where

group by

having

order by

以上关键字只能按照这个顺序来, 不能颠倒

4.13.2、执行顺序

from

on

join

where

group by //分组

having //过滤

select

distinct

order by //排序

4.13.3、解析

从某张表(或者是连接的多张表)中查询数据

on筛选出符合条件的行

根据join的类型把两张表的结果相连

经过where条件筛选出有价值的数据

对这些有价值的数据进行分组

分组之后可以使用 having 继续过滤筛选

select 查询出来

去重

最后排序输出

5、Mysql常用函数

5.1、常用函数

-- 数学运算
SELECT ABS(-8); -- 绝对值
SELECT CEIL(5.1); -- 向上取整
SELECT CEILING(5.1); -- 向上取整
SELECT RAND(); -- 返回0~1之间的一个随机数
SELECT SIGN(-10); -- 返回一个数的符号;0返回0;正数返回1;负数返回-1
-- 字符串函数
SELECT CHAR_LENGTH('法外狂徒'); -- 字符串长度
SELECT CONCAT('法外','狂','徒'); -- 拼接字符串
SELECT INSERT('我喜欢',1,1,'超级') -- INSERT(str,pos,len,newstr) 从str的pos位置开始替换为长度为len的newstr
SELECT UPPER('zsr'); -- 转大写
SELECT LOWER('ZSR'); -- 转小写
SELECT INSTR('zsrs','s'); -- 返回第一次出现字串索引的位置
SELECT REPLACE('加油就能胜利','加油','坚持'); -- 替换出现的指定字符串
SELECT SUBSTR('坚持就是胜利',3,6); -- 返回指定的字符串(源字符串,截取位置,截取长度)
SELECT REVERSE('rsz'); -- 反转字符串
-- 时间日期函数
SELECT CURRENT_DATE(); -- 获取当前日期
SELECT CURDATE(); -- 获取当前日期
SELECT now(); -- 获取当前时间
SELECT LOCALTIME(); -- 本地时间
SELECT SYSDATE(); -- 系统时间
SELECT DATE_FORMAT(now() ,'%Y-%m-%d %H-%m-%s' ) -- 格式化日期
SELECT STR_TO_DATE('21,5,2018','%d,%m,%Y'); -- 将时间格式的字符串(str),按照所提供的显示格式(format)转换为DATETIME类型的值
SELECT YEAR(NOW());
SELECT MONTH(NOW());
SELECT DAY(NOW());
SELECT HOUR(NOW());
SELECT MINUTE(NOW());
SELECT SECOND(NOW());
-- 系统信息
SELECT SYSTEM_USER();
SELECT USER();
SELECT VERSION();

5.2、聚合函数

函数 描述

max 最大值

min 最小值

sum 和

avg 平均值

count 计算个数

示例

SELECT COUNT(StudentName) FROM student; 
SELECT COUNT(*) FROM student;
SELECT COUNT(1) FROM student;
SELECT SUM(`StudentResult`) FROM result;
SELECT AVG(`StudentResult`) FROM result;
SELECT MAX(`StudentResult`) FROM result;
SELECT MIN(`StudentResult`) FROM result;


5.3、条件判断函数

5.3.1、CASE WHEN … THEN … ELSE … END

语法

CASE expression
WHEN if_true_expr THEN return_value1
WHEN if_true_expr THEN return_value2
WHEN if_true_expr THEN return_value3
……
ELSE default_return_value
END

示例1 : 用在更新语句的更新条件中

UPDATE users_info u 
SET u.balance =
CASE
  WHEN u.sex = '女' 
  AND u.age > 18 THEN
    u.balance + 10 ELSE u.balance + 5 
  END 
  WHERE
  u.create_time >= '2020-01-01'


示例2 : 用在查询语句的返回结果中

SELECT
  *,
CASE
    WHEN total_score >= 650 THEN
    '重点大学' 
    WHEN total_score >= 600 
    AND total_score < 650 THEN '一本' WHEN total_score >= 500 
      AND total_score < 600 THEN '二本' WHEN total_score >= 400 
        AND total_score < 500 THEN
          '三本' ELSE '大专' 
          END AS status_student 
    FROM
  student_score;

示例3 : 用在分组查询语句中

SELECT
    SUM(c.users_count) AS '用户数量',
    CASE c.city
        WHEN '济南'   THEN '山东省'
        WHEN '青岛'   THEN '山东省'
        WHEN '枣庄'   THEN '山东省'
        WHEN '广州'   THEN '广东省'
        WHEN '深圳'   THEN '广东省'
 ELSE '其他' END AS '归属省'
FROM
    users_area c
GROUP BY CASE c.city
        WHEN '济南'   THEN '山东省'
        WHEN '青岛'   THEN '山东省'
        WHEN '枣庄'   THEN '山东省'
        WHEN '广州'   THEN '广东省'
        WHEN '深圳'   THEN '广东省'
 ELSE '其他' END;

注意点

需要注意的点,Case函数只返回第一个符合条件的值,剩下的Case when部分将会被自动忽略

5.3.2、IF(expr,if_true_expr,if_false_expr)

在mysql中if()函数的用法类似于java中的三目表达式,具体语法如下:

IF(expr,if_true_expr,if_false_expr),如果expr的值为true,则返回if_true_expr的值,如果expr的值为false,则返回if_false_expr的值。

示例

SELECT
IF
  ( sex = '女', '1', '0' ) AS sex_code 
FROM
  employee

5.3.3、IFNULL(expr1,expr2)

IFNULL函数是MySQL控制流函数之一,它有两个参数,两个参数可以是真实值或表达式,如果expr1不是NULL,则返回第一个参数(expr1)。 否则,IFNULL函数返回第二个参数。

示例

SELECT `NAME`,IFNULL(sex,'未知') from student;


相关实践学习
自建数据库迁移到云数据库
本场景将引导您将网站的自建数据库平滑迁移至云数据库RDS。通过使用RDS,您可以获得稳定、可靠和安全的企业级数据库服务,可以更加专注于发展核心业务,无需过多担心数据库的管理和维护。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
7月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
484 158
|
7月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1171 152
|
7月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
897 156
|
7月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
500 156
|
7月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
7月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
7月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
7月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
7月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
600 161
|
8月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。

热门文章

最新文章

推荐镜像

更多