【1】    LOWER : 将字符串中的内容全部转成小写
             UPPER : 将字符串中的内容全部转成大写

SELECT LOWER ('abAcD')
FROM DUAL SELECT UPPER('abAcd')
FROM DUAL SELECT UPPER(first_name)
FROM employees

【2】CONCAT : 字符串拼接

SUBSTR :截取子串,从2的位置开始偏移量为3

LENGTH :长度

CONCAT('Hello', 'World')  HelloWorld
SUBSTR('HelloWorld',1,5) Hello
LENGTH('HelloWorld') 10
INSTR('HelloWorld', 'W') 6
LPAD(salary,10,'*') *****24000
RPAD(salary, 10, '*') 24000*****
TRIM('H' FROM 'HelloWorld') elloWorld
REPLACE('abcd','b','m') amcd

【3】  LPAD (右对齐)| RPAD (左对齐):
           TRIM : 清除字符串左右两端指定的字符
           REPLACE : 替换字符串中指定的某个字符

SELECT CONCAT ('aaa','bbb','ccc')abc
FROM DUAL SELECT CONCAT(first_name,'',last_name) NAME
FROM employees

【4】mysql的索引值是从1开始的,截取子串,从2的位置开始偏移量为3

SELECT SUBSTR('HelloMysql',2,3)
FROM DUAL SELECT LENGTH('Hello')
FROM DUAL SELECT INSTR('hellolo','lo')
FROM DUAL SELECT LPAD(first_name,10,'')
FROM employees SELECT TRIM(''FROM 'abc de')
FROM DUAL SELECT TRIM('#' FROM '####abc de#####')
FROM DUAL SELECT REPLACE('abcdef','a','A')
FROM DUAL

【5】数字函数

ROUND: 四舍五入
ROUND(45.926, 2) 45.93 TRUNCATE: 截断
TRUNCATE(45.926) 45 MOD: 求余
MOD(1600, 300) 100

SELECT ROUND(123.65,1) ,ROUND(123.53,0),ROUND(123.43,-1)
FROM DUAL SELECT TRUNCATE(123.65,1),TRUNCATE(123.53,0),TRUNCATE(123.53,-1)
FROM DUAL SELECT MOD(5,3),MOD(-5,3),MOD(5,-3),MOD(-5,-3)
FROM DUAL

【6】 日期函数  now() : 获取当前时间

SELECT NOW()
FROM DUAL

【7】   通用函数 : ifnull
             注意 :null和其它值做运算结果仍为null

SELECT employee_id,salary,12*salary*(1+commission_pct)
FROM employees; SELECT salary,commission_pct,salary * commission_pct
FROM employees
WHERE employee_id =100

【8】 IFNull(commission_pct,0) :如果commission_pct 的值为null那么就将值设置为0


SELECT employee_id,salary,12*salary*(1 + IFNULL(commission_pct,0))
FROM employees
WHERE employee_id = 100

【11】    练习:查询部门号为 10, 20, 30 的员工信息, 若部门号为 10,
               则打印其工资的 1.1 倍, 20 号部门, 则打印其工资的 1.2 倍,
               30 号部门打印其工资的 1.3 倍数

SELECT first_name,salary,department_id,
CASE department_id
WHEN 10 THEN salary * 1.1
WHEN 20 THEN salary * 1.2
WHEN 30 THEN salary * 1.3
ELSE salary * 1.4 END new_salary
FROM employees SELECT first_name,salary,job_id,
CASE job_id
WHEN 'IT_PROG' THEN salary*2
ELSE salary *1.4 END new_salary
FROM employees

【12】 AVG() : 求平均值
            SUM() :求和
            MAX() : 求最大值
            MIN() : 求最小值
            COUNT() : 求个数

 -- avg只能运算数值(double,int)
SELECT AVG(salary)
FROM employees SELECT SUM(salary)
FROM employees -- max,min 可以运算数值,字符串,日期
SELECT MAX(first_name),MAX(salary)
FROM employees

SELECT MIN(first_name),MIN(salary)
FROM employees

【13】count:统计的个数不包含数值为null

SELECT COUNT(salary),COUNT(commission_pct)
FROM employees

SELECT AVG(salary),SUM(salary)/107,SUM(salary)/COUNT(commission_pct)
FROM employees

【14】 需求:求表中的数据有多少

SELECT COUNT(*),COUNT(1),COUNT(2)
FROM employees

SELECT first_name
FROM employees
WHERE 1 =1; -- 可以理解为没有条件

【15】    group by

①  需求:求所有员工的平均工资

SELECT AVG(salary)
FROM employees -- 下面的写法是错误的
SELECT first_name,AVG(salary)
FROM employees

② 需求: 求各部门员工的平局工资

如果列中出现了组函数和其他的列。那么其他的列必须作为
group by 后面分组的条件 SELECT department_id,AVG(salary)
FROM employees
-- group by 按照什么样的格式来分组
GROUP BY department_id

③需求:求各部门中不同工种的员工的平均工资

SELECT department_id, job_id,AVG(salary)
FROM employees
GROUP BY department_id,job_id SELECT department_id, job_id,AVG(salary)
FROM employees
-- group by 后面的两个列交换顺序是没有区别的
GROUP BY job_id,department_id

【16】 having

①需求 :求各个部门中最高工资大于10000的部门
-- 注意 :如果过滤条件中出现了组函数,那么只能放在having后面使用

SELECT department_id,MAX(salary)
FROM employees
GROUP BY department_id
HAVING MAX(salary)>10000

②需求:求 20,30,40部门中最高工资大于10000的部门

SELECT department_id,MAX(salary)
FROM employees
GROUP BY department_id
HAVING MAX (salary)>10000 AND department_id IN (20,30,40) -- 下面的方式比上面的好
SELECT department_id,MAX(salary)
FROM employees
WHERE department_id IN(20,30,40)
GROUP BY department_id
HAVING MAX(salary)>10000 DESC customers
INSERT INTO customers(NAME,email,birth) VALUES('鲁宾','ccc.@.qq.com','1196-02-56')

数据库之 MySQL --- 数据处理 之 单行函数、组函数 (四)的更多相关文章

  1. 数据库之 MySQL --- 数据处理 之 表的约束与分页(七)

    个人博客网:https://wushaopei.github.io/    (你想要这里多有)     1.约束 :为了保证数据的一致性和完整性,SQL规范以约束的方式对表数据进行额外的条件限制 ​ ...

  2. 数据库之 MySQL --- 数据处理 之 表操作、CRUD(六)

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一. 表操作 创建数据库CREATE DATABASE demo-- 删除数据库DROP DATABAS ...

  3. 数据库之 MySQL --- 数据处理 之 子查询 (二)

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一 .数据库语言定义及命令行查看数据库操作 -- SQL 语言可以分为三类-- DML: 数据操纵语言. ...

  4. 数据库之 MySQL --- 数据处理 之 多行子查询(五)

    ​ [1]需求: 谁的工资比Abel 高?方式一: 第一步线查出Abel共子 第二部进行过滤 SELECT salary FROM employees WHERE last_name = 'Abel' ...

  5. 数据库之 MySQL --- 数据处理 之多表查询 (三)

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.多表查询 [1]什么是多表查询? 即,从多个表中获取数据. 注意: 在多表查询是,如果列明在两个表中 ...

  6. MySQL-第九篇分组和组函数

    1.组函数 组函数:即多行函数,组函数将一组记录作为整体计算,每组记录返回一个结果,而不是每条记录返回一个结果. 2.常用的组函数有: 1>avg([distinct|all]expr):计算多 ...

  7. Netsuite Formula > Oracle函数列表速查(PL/SQL单行函数和组函数详解).txt

    PL/SQL单行函数和组函数详解 函数是一种有零个或多个参数并且有一个返回值的程序.在SQL中Oracle内建了一系列函数,这些函数都可被称为SQL或PL/SQL语句,函数主要分为两大类: 单行函数 ...

  8. 【数据库】MySql常用函数梳理

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/5866388.html MySql常用函数梳理: 1:数学函数 使用格式:一般用于插入.修改语句中,直接 函数( ...

  9. Oracle组函数、多表查询、集合运算、数据库对象(序列、视图、约束、索引、同义词)等

    count组函数:(过滤掉空的字段) select count(address),count(*) from b_user max() avg() min(),sum() select sum(age ...

随机推荐

  1. 环境篇:Superset

    环境篇:Superset Superset 是什么? Apache Superset 是一个开源.现代.轻量的BI分析工具,能够对接多种数据源,拥有丰富的图表展示形式.支持自定义仪表盘,用户界面友好, ...

  2. 如何快速理解Spring中的DI和AOP

    前言 Spring框架通过POJO最小侵入性编程.DI.AOP.模板代码手段来简化了Java 开发,简化了企业应用的开发.POJO和模板代码相对来说好理解,本篇重点解读下DI和AOP. 一 DI DI ...

  3. ASP.NET Core on K8S学习之旅(12)Ingress

    本篇已加入<.NET Core on K8S学习实践系列文章索引>,可以点击查看更多容器化技术相关系列文章. 一.关于Ingress Kubernetes对外暴露Service主要有三种方 ...

  4. A*启发式搜索

    A*启发式搜索 其实是两种搜索方法的合成( A*搜索算法 + 启发式搜索),但要真正理解A*搜索算法,还是得先从启发式搜索算法谈起. 何为启发式搜索 启发式搜索算法有点像广度优先搜索,不同的是,它会优 ...

  5. screen命令两种用法

    screen命令用法举例 screen命令,故名思议于屏幕有关. 1. screen用于关闭shell应用不退出 思路:创建一个单独的shell窗口,在此窗口中启动应用,然后把这个shell放置于后台 ...

  6. iOS事件的响应和传递机制

    跟二狗子哥哥交流的时候,他总说我,说的过程太业余.故 好好学习整理一下.努力不那么业余. 一.事件的产生.传递.响应: 1.事件从父控件依次传递到子控件,寻找最合适的子控件View. 2.寻找最合适的 ...

  7. watch 和 计算属性

    作者:纵横链接:https://www.zhihu.com/question/55846720/answer/331760496来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

  8. (Python基础教程之八)Python中的list操作

    Python基础教程 在SublimeEditor中配置Python环境 Python代码中添加注释 Python中的变量的使用 Python中的数据类型 Python中的关键字 Python字符串操 ...

  9. JS的IIFE

    1. 定义 IIFE: Immediately Invoked Function Expression,意为立即调用的函数表达式,也就是说,声明函数的同时立即调用这个函数. 首先我们要了解一般情况下什 ...

  10. JVM系列(2)-GC

    1.什么是GC? 大白话说就是垃圾回收机制,内存空间是有限的,你创建的每个对象和变量都会占据内存,gc做的就是对象清除将内存释放出来,这就是GC要做的事. 2.需要GC的区域 说起垃圾回收的场所,了解 ...