MySQL数据库第十一课---------SQl语句的拔高-------水平提升

这篇具有很好参考价值的文章主要介绍了MySQL数据库第十一课---------SQl语句的拔高-------水平提升。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

作者前言

                                

                 个人主页::小小页面

                 gitee页面:秦大大

                一个爱分享的小博主 欢迎小可爱们前来借鉴

______________________________________________________   

目录

SQL提高

 日期函数

        length

        round

        reverse

        substring

        ifnull

        case when

        cast

        grouping sets

排序函数

 开窗函数
 

 ____________________________________________________________________

  

内置函数

日期函数

now()

select now();

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 获取当前时间(获取到秒)

year()

select year(now());

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 获取当前的年,注意一下year()里的()要填now()

month()

select month(now());

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

获取当前月份 

day()

select day(now());

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 获取当前的日期

length

select first_name, length(first_name) from new_employees limit 0,10;

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 查看字符长度

round

select round(1.22, 3)

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

注意一下,这里的保留小数不会自动补全,会四舍五入

reverse() 

字符串翻转

select first_name, reverse(first_name) from new_employees limit 0,10;

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

substring()

截取字符串

-- 截取字符串
-- start开始的位置,如果没有则默认从第一位开始,length截取的长度
SUBSTRING(column, start, length)

column:字段

start:从哪一位开始

length:截取的长度

select first_name, substring(first_name,1,5) from new_employees limit 0,10;
MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

ifnull()

判空

会把null(空)变成别名

select ifnull(`daa`, '111') from aaa;;

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

  isnull

 nvl

coalesce

这三个都是一样的效果

case when(当...)

这个函数一点特别,就拿python的if ...elif....else(或者C语言的if.....else if.....else)来说,我们只需写好条件和代码块就行了,但是这个函数的写法是这样的

select 
case when 条件
    then '运行内容1'
when 条件
    then '运行内容2'
else "运行内容"

end  as  别名

其实sql语句没有格式,这样写是为了让大家好看,when 相当于else if()  

cast

以前的数据库的不同类型的数据不能相加和相减的,而现在的数据库有些可以,mysql就是之一

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 现在已经不支持了,这里演示不了

-- cast(column as data_type)
-- 更改字段类型
select cast(column as int(10)) from table
select cast(column as char(10)) from table

grouping sets

前面我们学过一个分组,group by,这个方法把所有的符合条件的分成一组,只显示出集体,不显示出个人,简单理解为分组加聚合

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

如图,而grouping sets

这个在mysql中也无法使用,但是我们可以做出这样的效果

select
depart
,gender
,count(id) cnt
from table
grouping sets(
(depart) -- 部门维度
,(gender) -- 性别维度
,(depart, gender) -- 部门及性别的维度
,() -- 不分组,全部人数
​​​​​​​)

但是我们可以分析一下 利用这个方法相对于进行了三次分组然后再利用union distinct连接起来

第一次是分组depart

第二次是分组gender

第三次分组depart, gender

代码:

select
coalesce(gender, '人和1')
, null `age`
, count(0)
from new_employees
group by `gender`
with rollup
union distinct
select
null `gender`
, coalesce(age, '人和2')
, count(0)
from new_employees
group by `age`
with rollup
union distinct
select
`gender`
, `age`
, count(0)
from new_employees
group by`gender`, `age`
with rollup;

结果:

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 排序函数

在前面中我们学过一个order by

​​​​​​​​​​​​​​MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 而这个排序函数起到的就是给个编号这样可以方便我们查找

分三类

row_number() over()  as 别名   ====》从小到大,依次往下

rank() over() as 别名   ======》从小到大 相同数据位居一样,但是不同数据名次依旧

dense_rank()  over() as 别名  =====》从小到大,相同数据位居一样  名次从1开始无断层

-- row_number() 根据选择字段排序,若存在相同数据,则随机排顺序
-- 根据年龄从大到小排序
select
row_number() over(order by age desc) rk
from table
-- rank() 根据选择字段排序,若存在相同数据,则并列名次,但是名次个数任然占用
-- 根据年龄从小到大排序
select
rank() over(order by age) rk
from table
-- dense_rank() 根据选择字段排序,若存在相同数据,则并列名次,但是名次个数不占用
-- 根据年龄从小到大排序
select
dense_rank() over(order by age) rk
from table

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql                            MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql   

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 开窗函数

-- function([column]) OVER(partition by column [order by column])
-- function通常为聚合函数,也可以是排序的函数
-- 根据性别和年龄分组,对身高进行排序
select
row_number() over(partition by gender, age order by high) rk
from table
-- 根据性别和年龄分组,求出人数
select
count(id) over(partition by gender, age) cnt
from table
where id is not null

记住一定要有函数function,可以是avg() sum()等

partition by 是我们可以理解为是group by 的前半身,只分组不聚合,因为group by有有聚合的效果,而开窗函数缺少聚合效果,简单的说分组男女性别,就是会显示出哪个人是男性及相关信息

row_number() over () as 别名

select
emp_no
,age
,dept_no
,gender
,row_number() over(partition by dept_no,gender order by age desc) as kkk
from (
select
a.emp_no
,a.age
,a.gender
,b.dept_no
from new_employees as a join dept_emp as b on a.emp_no =b.emp_no
) as c
limit 30;

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 count(0)over()as 别名

select
emp_no
,age
,dept_no
,gender
,count(1) over(partition by dept_no,gender) as kkk
from (
select
a.emp_no
,a.age
,a.gender
,b.dept_no
from new_employees as a join dept_emp as b on a.emp_no =b.emp_no limit 30
) as c;

MySQL数据库第十一课---------SQl语句的拔高-------水平提升,数据库,mysql

 可以看出kkk有重复的数据,就拿第一条数据说 这条数据属于这19个数据,如果把count函数替换成avg(age)就可以明确哪个人超出平均值,哪些人没有超出

总结:

关于sql语句先介绍到这里,有不懂的小可爱可以私聊文章来源地址https://www.toymoban.com/news/detail-603300.html

到了这里,关于MySQL数据库第十一课---------SQl语句的拔高-------水平提升的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据库】MySQL 高级(进阶) SQL 语句

    location表格创建 store_info表格创建 显示表格中一个或数个字段的所有数据记录 不显示重复的数据记录 按照条件进行查询 在已知的字段数据取值范围内取值 另外还有not in命令,用法一致,表示显示不在指定范围内的字段的值。 在两个字段数据值之间取值,包含两边字段的数据

    2024年02月09日
    浏览(17)
  • 【MySQL】数据库SQL语句之DML

    目录 前言: 一.DML添加数据 1.1给指定字段添加数据 1.2给全部字段添加数据 1.3批量添加数据 二.DML修改数据 三.DML删除数据 四.结尾   时隔一周,啊苏今天来更新啦,简单说说这周在做些什么吧,上课、看书、放松等,哈哈哈,所以博客就这样被搁了。   今天感觉不错,给大

    2024年02月08日
    浏览(15)
  • 【MySQL数据库 | 第十九篇】SQL性能分析工具

    目录   前言: SQL执行频率: 慢查询日志: profile: profile各个指令: 总结:         本篇我们将为大家讲解SQL性能的分析工具,而只有熟练的掌握了性能分析的工具,才可以更好的对SQL语句进行优化。虽然我们在自己练习的时候对这种优化感知并不明显,但是如果我们要

    2024年02月09日
    浏览(16)
  • MySQL数据库第十四课--------sql优化---------层层递进

    🎂 ✨✨✨✨✨✨🍧🍧🍧🍧🍧🍧🍧🎂 ​🎂 作者介绍: 🎂🎂 🎂 🎉🎉🎉🎉🎉🎉🎉 🎂 🎂作者id:老秦包你会, 🎂 简单介绍:🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂 喜欢学习C语言和python等编程语言,是一位爱分享的博主,有兴趣的小可爱可以来互讨 🎂🎂

    2024年02月12日
    浏览(22)
  • MySQL相关的SQL语句、数据库、数据表、字段、类型

    1、 SQL 语句不区分大小写。 SQL语句 用途 描述 mysql -u root -p 连接 MySQL 在命令行窗口中输入 mysql -u root -p 命令,回车,然后输入 MySQL 密码(不要忘记了密码,找回麻烦),再回车就连接上 MySQL 了。最初都是使用 root 用户登录,工作中不能一直使用 root 用户登录。因为 root 权限太

    2024年02月13日
    浏览(38)
  • MySQL数据库中的索引(含SQL语句)

    假设有一张表,表中有100万条数据,这100万条数据在硬盘上是存储在数据页上的,一页数据大小为16k。存储100万条数据那么就需要数据页,假设其中有一条数据是“id为7900”的,那么如果要查询这条数据,其中SQL是SELECT * FROM 表名 WHERE id = 7900。在执行这条SQL语句的时候,MyS

    2024年02月02日
    浏览(32)
  • mysql,用sql语句,建立学生-课程数据库基本表

    学生表 学号 姓名 年龄 性别 院系 Student Sno Sname Sage Ssex Sdept 课程表 课程号 课程名 先行课 学分 Course Cno Cname Cpno Ccredit 选课表 学号 课程号 成绩 SC Sno Cno Grade 注意创建表的时候要注意它的字段名,类型,长度,约束条件,取值范围要合适,大小写符号要正确,中文逗号,分号

    2024年02月08日
    浏览(20)
  • MySQL数据库概念、管理以及SQL语句的基本命令操作

    数据(data) 描述事物的符号记录 包括数字,文字、图形、图像、声音、档案记录等 以“记录”形式按统一格式进行存储(记录可以看成一条记录) 表 将不同的记录组织在一起 用来存储具体数据 记录:行 字段(属性):列 以行+列的形式就组成了表(数据存储在表中) 数

    2024年02月08日
    浏览(20)
  • MySQL 数据库实用指南:测试数据准备、SQL语句规范与基本操作

    欢迎来到小K的MySQL专栏,本节将为大家准备MySQL测试数据、以及带来SQL语句规范、数据库的基本操作的详细讲解 要学习SQL查询语句,首先必须解决一个问题,数据问题。为了方便大家学习阅读我的文章,在这里提供了一个test.sql文件 ✨ 登录MySQL,输入 source xxx/test.sql 导入sql文

    2024年02月08日
    浏览(30)
  • MySQL数据库增删改查及聚合查询SQL语句学习汇总

    目录 数据库增删改查SQL语句 MySQL数据库指令 1.查询数据库 2.创建数据库 3.删除数据库 4.选择数据库 创建表table   查看所有表 创建表 查看指定表的结构 删除表 数据库命令进行注释 增删改查(CRUD)详细说明 增加 SQL库提供了关于时间的函数:now()  查询 查询表作列与列之间进

    2024年02月09日
    浏览(20)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包