SQL的函数

函数就是将我们经常使用的代码封装起来, 需要的时候直接调用, 提高代码效率和可维护性.

SQL函数一般是在数据上执行, 可以方便地转换和处理数据.

常用的SQL函数

SQL提供了一些常用的内置函数, 也可以自定义, 内置的函数分为四类:

  • 算数函数
  • 字符串函数
  • 日期函数
  • 转换函数

算数函数

算数函数, 其实就是对数据类型的字段进行算术运算, 常用的如下:

SELECT ABS(-2);  // 2
SELECT MOD(101, 3); // 2
SELECT ROUND(37.25, 1); // 37.3

字符串函数

常用的字符串函数如下:

SELECT CONCAT('abc', 123); // abc123
SELECT LENGTH('你好'); // 6
SELECT CHAR_LENGTH('你好'); // 2
SELECT LOWER('ABC'); // abc
SELECT UPPER('abc'); // ABC
SELECT REPLACE('fabcd', 'abc', 123); // f123d
SELECT SUBSTRING('fabcd', 1,3); // fab

日期函数

常用函数如下:

SELECT CURRENT_DATE;  // 获取当前日期
SELECT CURRENT_TIME; // 获取当前时间
SELECT CURRENT_TIMESTAMP; // 获取当前日期 + 时间(时间戳)
SELECT EXTRACT(YEAR FROM '2019-07-07'); // 获取日期年
SELECT EXTRACT(MONTH FROM '2019-07-07'); // 获取日期月
SELECT EXTRACT(DAY FROM '2019-07-07'); // 获取日期天
SELECT DATE('2019-07-07 09:54:00'); // 获取日期
SELECT TIME('2019-07-07 09:54:00'); // 获取时间
SELECT TIMESTAMP('2019-07-07 09:54:00'); // 获取时间戳

以后日期类型的比较实用DATE()函数来进行. 这点很重要.

转换函数

转换函数的作用是用来转换数据类型的

SELECT CAST(123.123 AS INT);  // 报错, 原数值有小数, 不会四舍五入, 转换出错
SELECT CAST(123.123 AS DECIMAL(8,2)); // 8表示整数+小数总共8位,2表示小数位数有两位
SELECT COALESCE(NULL, 1, 2); // 第一个部位null的数是1

聚集函数

聚集函数是对一组数据进行汇总的函数, 输入一组数据, 输出的是单个值. SQL中的聚集函数一共包括5个

SELECT COUNT(*) FROM heros WHERE hp_max > 6000; // 查询最大生命值大于6000的英雄数量
SELECT MAX(hp_max) FROM heros WHERE role_main = '射手' or role_assist = '射手'; // 查询主要定位和次要定位都是射手的英雄的最大生命值
SELECT COUNT(*), AVG(hp_max), MAX(mp_max), MIN(attack_max), SUM(defense_max) FROM heros WHERE role_main = '射手' or role_assist = '射手'; // 一次使用多个聚合函数
SELECT ROUND(AVG(DISTINCT hp_max), 2) FROM heros; // 计算最大生命的平均值,并保留小数点后两位

注意MAX, MIN, AVG函数会自动忽略值为NULL的数据行.

数据的分组和统计

对数据进行分组需要使用到GROUP BY子句:

SELECT COUNT(*), role_main FROM heros GROUP BY role_main; // 按照英雄的主要定位分组, 并统计每组的英雄数量
SELECT COUNT(*) as num, role_main, role_assist FROM heros GROUP BY role_main, role_assist ORDER BY num DESC; // 多个字段进行分组, 并按照数量进行降序排序

HAVING过滤分组

使用WHERE 条件可以进行数据的过滤, 但是在分组的时候, 过滤并不能使用WHERE, 而是需要使用HAVING, 简单的说WHERE用于数据行, HAVING用于分组.

SELECT COUNT(*) as num, role_main, role_assist FROM heros GROUP BY role_main, role_assist HAVING num > 5 ORDER BY num DESC; // 按照主要定位和次要定位进行分组, 查询数量大于5的分组并降序排序
SELECT COUNT(*) as num, role_main, role_assist FROM heros WHERE hp_max > 6000 GROUP BY role_main, role_assist HAVING num > 5 ORDER BY num DESC; // WHERE和HAVING同时使用, WHERE先排除数据行, 之后分组过滤

SELECT的查询语句中, 关键字的顺序是不能颠倒的:

SELECT.....FROM......WHERE......GROUP BY......HAVING......ORDER BY......LIMIT......

SQL的简单函数(极客时间)的更多相关文章

  1. 极客时间 Mysql实战45讲 07讲行锁功过:怎么减少行锁对性能的影响笔记 极客时间

    极客时间 Mysql实战45讲 07讲行锁功过:怎么减少行锁对性能的影响笔记 极客时间极客时间 Mysql实战45讲 07讲行锁功过:怎么减少行锁对性能的影响笔记 极客时间 笔记体会: 方案一,事务相 ...

  2. Mysql实战45讲 05讲深入浅出索引(下)极客时间 读书笔记

    极客时间 Mysql实战45讲 04讲深入浅出索引(下)极客时间 笔记体会: 回表:回到主键索引树搜索的过程,称为回表覆盖索引:某索引已经覆盖了查询需求,称为覆盖索引,例如:select ID fro ...

  3. Mysql实战45讲 04讲深入浅出索引(上)读书笔记 极客时间

    极客时间 Mysql实战45讲 04讲深入浅出索引 极客时间(上)读书笔记  笔记体悟 1.索引的作用:提高数据查询效率2.常见索引模型:哈希表.有序数组.搜索树3.哈希表:键 - 值(key - v ...

  4. java爬虫系列第四讲-采集"极客时间"专栏文章、视频专辑

    1.概述 极客时间(https://time.geekbang.org/),想必大家都知道的,上面有很多值得大家学习的课程,如下图: 本文主要内容 使用webmagic采集极客时间中某个专栏课程生成h ...

  5. 【视频合集】极客时间 react实战进阶45讲 【更新中】

    https://up2.v.sharedaka.com/video/ochvq0AVfpa71A24bmugS5EewhFM1553702519936.mp4 01 React出现的历史背景及特性介绍 ...

  6. "做中学"之“极客时间”课程学习指导

    目录 "做中学"之"极客时间"课程学习指导 所有课程都可以选的课程 Java程序设计 移动平台开发 网络攻防实践 信息安全系统设计基础 信息安全专业导论 极客时 ...

  7. 如何将极客时间课程制作成kindle电子书

    订阅了几个极客时间的专栏,一直没有时间去看. 最近,想着如果把内容制作成电子书,利用上下班时间学习一下,岂不是很方便? 在网上搜到一个很好用的开源软件,几分钟就可以把极客时间的专栏做成电子书,简直太棒 ...

  8. 极客时间_Vue开发实战_汇总贴

    视频地址: https://time.geekbang.org/course/intro/163 https://github.com/tangjinzhou/geektime-vue-1 电脑dem ...

  9. 左耳朵耗子:我为什么要在极客时间 App 开设独家专栏?

    参考链接:https://www.infoq.cn/article/2018/01/why-geektime 不少朋友都知道我在极客时间App 上开了一个收费专栏<左耳听风>,这个专栏会开 ...

随机推荐

  1. c语言的全排列

    在c语言中实现全排列,对于刚接触c语言,还没学习算法的人来说,比较困难了吧.估计大佬也不会看这种基础的东西,全排列实现的办法很多,在c++中有一个专门的函数可以使用,但是在c中实现就有点困难了.如果你 ...

  2. C++中的传值与传址

    在指针的传递中,也涉及到传值与传址的问题.下面通过一个函数进行说明. 代码如下: bool openBinary(uchar* buffer) { ; buffer = (uchar*)malloc( ...

  3. git clone克隆代码显示“无权限或者确认存储库是否存在”

    今天我用公司的电脑要继续完成我自己的git上的小项目的时候,发现git clone失败,提示 然后我在公司电脑上生成公钥感觉又太麻烦了 网上找了个好方法就是把自己电脑上的.ssh文件夹拷贝到公司电脑上 ...

  4. centos7下关闭防火墙

    查看防火墙:systemctl status firewalld.service 关闭防火墙:systemctl stop firewalld.service 以上方式是暂时的,重启系统则防火墙仍然开 ...

  5. 《高性能MySQL》读后感——聚簇索引

    <高性能MySQL>读后感——聚簇索引 聚簇索引并不是一种单独的索引类型,而是一种数据存储方式.比如,InnoDB的聚簇索引使用B+Tree的数据结构存储索引和数据. 当表有聚簇索引时,它 ...

  6. BZOJ1688 「USACO05OPEN」Disease Manangement 背包+状压DP

    问题描述 BZOJ1688 题解 背包,在转移过程中使用状压. \(\mathrm{Code}\) #include<bits/stdc++.h> using namespace std; ...

  7. BZOJ2733/LG3324 「HNOI2014」永无乡 权值线段树合并

    问题描述 BZOJ2733 LG3224 题解 对于每个结点建立一棵权值线段树. 查询操作就去查询第 \(k\) 大,合并操作就合并两颗权值线段树. 并查集维护连通性. 同时 STO hkk,zcr, ...

  8. VScode Python 虚拟环境

    安装python环境 在VScode里设置Python 虚拟环境查找路径(Settings -> Extensions -> Python Configurations -> Env ...

  9. JAVA基础系列:ThreadLocal

    1. 思路 什么是ThreadLocal?ThreadLocal类顾名思义可以理解为线程本地变量.也就是说如果定义了一个ThreadLocal,每个线程往这个ThreadLocal中读写是线程隔离,互 ...

  10. Hbase 多条件查询

    /** * 获得相等过滤器.相当于SQL的 [字段] = [值] * @param cf 列族名 * @param col 列名 * @param val 值 * @return 过滤器 */ pub ...