• Mysql内置函数、复合查询和内外连笔记


    目录

    一、mysql内置函数

    1.1.日期函数

    1.2.字符串函数

    1.3.数学函数

    1.4.其他函数

    二、复合查询

    2.2 自连接

    2.3 子查询

    2.3.1单行自查询

    2.3.2 多行子查询

     2.3.3 多列子查询

    2.3.4在from子句中使用子查询

    2.3.5合并查询

    三、表的内连和外连

    3.1内连接

    3.2外连接

    3.2.1 左外连接

    3.2.2右外连接

    一、mysql内置函数

    1.1.日期函数

     获得时间:

    🖊获得年月日:select current_date();

    🖊获得时分秒:select current_time();

    🖊获得时间戳:select current_timestamp();

    🖊在日期的基础上加日期:

    🖊在日期的基础上减去时间:

     

    🖊计算两个日期之间相差多少天:

     

    案例:

    创建一个留言表:

    插入数据:

    显示所有留言信息,发布日期只显示日期,不用显示时间:

     

    查询在五分钟内发布的贴子:

     🖊:select *from msg where date_add(sendtime,interval 5 minute)>now();

    或🖊:select *from msg where date_sub(now(),interval 5 minute)

    理解:

    1.2.字符串函数

     案例:

    sql获取:码云

    案例:

    获取emp表的ename列的字符集:

    要求显示exam_result表中的信息,显示格式:“XXX的语文是XXX分,数学XXX分,英语XXX分”

    求学生表中学生姓名占用的字节数:

    注意:length函数返回字符串长度,以字节为单位。如果是多字节字符则计算多个字节数;如果是单字节字符则算作一个字节。比如:字母,数字算作一个字节,中文表示多个字节(与字符集编码有关)。

    将emp表中所有名字中有S的替换为‘北京’

    截取emp表中ename字段的第二个到第三个字符

     

    以首字母小写的方式显示所有员工的姓名:

    select concat(lcase(substring(ename,1,1)),substring(ename,2)) from emp;

    1.3.数学函数

    绝对值:select abs();

    向上取整:select ceiling();

    向下取整: select floor();

    理解:

    向上取整简单来说,就是向大的整数方向取整,舍弃小数部分。比如23.04向上取整就是24,-5.9向上取整就是-5.

    同理,向下取整是朝着小的整数取整,舍弃小数部分。3.7向下取整是3.-1.3向下取整是-2.

    向0取整,是朝0靠拢,5.6向零取整是5,-6.6向0取整是-6

    保留n位小数位数:select format(小数,n);

    产生随机数:select rand();

    mysql中,产生随机数,产生的是0-1的小数。

    如果要得到0-100的随机数:

    1.4.其他函数

    🖊user()查询当前用户

    select user();

    🖊md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串

    通常用于加密。

    🖊password()函数,mysql数据库使用该函数对用户进行加密

    🖊ifnull(val1,val2)如果val1为null,返回val2,否则返回val1的值。

    二、复合查询

    2.1.多表查询

    实际开发中往往数据来自不同的表,所以需要多表查询。在此借用一个简单的公司管理系统,还是从码云下载。有三张表emp,dept,salgrade来演示如何进行多表查询。

    案例:

    🖊显示雇员名、雇员工资以及所在部门的名字因为上面的数据来自emp表和dept表,因此要联合查询。

    这种结果称为笛卡尔积。

    🖊显示部门号为10的部门名,员工名和工资

    🖊显示各个员工的姓名,工资,及工资级别

    2.2 自连接

    自连接是指在同一张表连接查询

    案例:员工FORD的上级领导的编号和姓名(mgr是员工领导的编号)

    🖊使用的子查询:

    🖊使用多表查询(自查询)

    2.3 子查询

    子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询。

    2.3.1单行自查询

    返回一行记录的子查询

    🖊显示SMITH同一部门的员工

    2.3.2 多行子查询

     返回多行记录的子查询

    🖊in关键字;

    查询和10号部门的工作岗位相同的雇员的名字,岗位,工资,部门号,但是不包含自己的。

    🖊all关键字;

    显示工资比部门30的所有员工的工资高的员工的姓名,工资和部门号

    第一种方式,当然可以找出部门30最高的工资,只要比这个工资高即可:

    比部门30所有的员工工资高,使用all: 

    🖊any关键字:显示工资比部门30的任意一个员工工资高的员工的姓名,工资和部门号

     2.3.3 多列子查询

    单行子查询是指子查询只返回单列,单行数据;多行子查询是指返回单列多行数据,都是针对单列而言的,而多列子查询则是指查询返回多个列数据的子查询语句。

    案例: 查询和SMITH的部门和岗位完全相同的所有雇员,不包含SMITH本人。

    2.3.4在from子句中使用子查询

    子查询语句出现在from子句中。子查询当作一个临时表使用。

    🖊显示每个高于自己部门平均工资的员工的姓名、部门、工资、平均工资

    🖊查找每个部门工资最高的人的姓名,工资,部门,最高工资。

    🖊显示每个部门的信息(部门号,编号,地址)和人员数量

    2.3.5合并查询

    🖊union

    union操作符用于取得两个结果集的并集,当使用该操作符时,会自动去掉结果集中的重复行。

    案例:将工资大于2500或职位是MANAGER的人找出来

    去掉了重复数据:

    🖊union all

    该操作符用于取得两个结果集的并集。当使用该操作符时,不会去掉结果集中的重复行。

    案例:将工资大于25000或职位是MANAGER的人找出来

    三、表的内连和外连

    3.1内连接

    内连接实际上就是利用where子句对两种表形成的笛卡尔积进行筛选,前面讲述的都是内连接,实际开发过程中使用最多的连接查询。

    语法:

            select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

    案例:显示SMITH的名字和部门名称:

    之前的写法:

    标准的内连接写法:

    3.2外连接

    外连接分为左外连接和右外连接

    3.2.1 左外连接

    如果联合查询时左侧的表完全显示我们就说是左外连接。

    语法: select 字段名 from 表1 left join 表2 on 连接条件

    案例:

    建两张表:

    🖊查询所有学生的成绩,如果这个学生没有成绩,也要讲学生的个人信息显示出来

    --当左边表和右边表没有匹配时,也会显示左边表的数据

    3.2.2右外连接

    语法:select 字段 from 表1 right join 表2 on 连接条件

    案例:对stu表和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来。

  • 相关阅读:
    HDR和泛光
    Spring Security笔记
    [JS真好玩] 遇到表格,手动翻页太麻烦?我教你写脚本,一页展示所有数据
    arm麒麟安装mysql
    ChatGPT实践-构建简单的AI聊天机器人(python)
    AtCoder Beginner Contest 276 G.Count Sequences(计数/组合数学)
    2022强网杯青年赛MISC1和MISC3,Crypto2 部分writeup
    leetcode 20
    MyBatis基于配置文件实现对数据库的增删改查
    物联网应用系统与网关
  • 原文地址:https://blog.csdn.net/JJR_YZ/article/details/133551829