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)<sendtime;

理解:

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表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/128269.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LabVIEW利用以太网开发智能液位检测仪

LabVIEW利用以太网开发智能液位检测仪 目前&#xff0c;工业以太网接口在国内外的发展已经达到了相当深入的程度&#xff0c;特别是在自动化控制和工业控制领域有着非常广泛的应用。在工业生产过程中&#xff0c;钢厂的连铸机是前后的连接环节&#xff0c;其中钢水从大钢包进入…

【云笔记篇】Microsoft OneNote笔记分区数据删除方法

【云笔记篇】Microsoft OneNote笔记分区数据删除方法 Microsoft OneNote删除分区数据需要在网页端操作才能彻底删除—【蘇小沐】 1、实验 系统版本Windows 11 专业工作站版22H2&#xff08;22621.1485&#xff09;&#xff1b;OneNoteOneNote 2016(版本 2303 Build 16.0.162…

苹果系统_安装matplotlib__pygame,以pycharm导入模块

为了更便捷、连贯的进行python编程学习&#xff0c;尽量在开始安装python软件时&#xff0c;将编辑器、模块一并安装好&#xff0c;这样能避免以后版本冲突的问题。小白在开始安装pycharm、pip、matplotlib往往会遇到一些问题&#xff0c;文中列示其中部分bug&#xff0c;供大家…

BLIP2模型加载在不同设备上

背景 现在大语言模型越来越大&#xff0c;占用的内存越来越多&#xff0c;这导致内存较小的设备无法体验大模型的效果。transformer提供了将一个大模型分别加载在gpu和cpu上的方法。 加载方法 以多模态模型BLIP2为例&#xff0c;将其语言模型放在gpu上&#xff0c;其余部分放…

C++ day2

自己封装一个矩形类(Rect)&#xff0c;拥有私有属性:宽度(width)、高度(height)&#xff0c; 定义公有成员函数: 初始化函数:void init(int w, int h) 更改宽度的函数:set_w(int w) 更改高度的函数:set_h(int h) 输出该矩形的周长和面积函数:void show() #include <ios…

创作2周年?浅记一下~

前言&#xff1a; 最近确实有点缺乏去更新博客的动力&#xff0c;一晃两年过去了&#xff0c;其实也是我新入职公司的两年&#xff0c;两年虽然不长&#xff0c;但是确实发生了太多事情值得去记录下来... 机缘 说是机缘也不是算是&#xff0c;第一次写博客是刚好在CSDN里面查资…

MyBatisPlus(十一)包含查询:in

说明 包含查询&#xff0c;对应SQL语句中的 in 语句&#xff0c;查询参数包含在入参列表之内的数据。 in Testvoid inNonEmptyList() {// 非空列表&#xff0c;作为参数List<Integer> ages Stream.of(18, 20, 22).collect(Collectors.toList());in(ages);}Testvoid in…

四位十进制频率计VHDL,DE1开发板验证,仿真和源码

名称&#xff1a;四位十进制频率计VHDL&#xff0c;DE1开发板验证 软件&#xff1a;Quartus 语言&#xff1a;VHDL 要求&#xff1a; 数字频率计设计要求 1、四位十进制数字显示的数学式频率计,其频率测量范围为10~9999khz,测量单位为kHz。 2、要求量程能够转换。即测几十…

网工内推 | IT高级运维工程师,周末双休,包吃包住,14-20k

01 深圳朗特智能控制股份有限公司 招聘岗位&#xff1a;IT高级运维工程师 职责描述&#xff1a; 1、对集团网络基础架构的建设、运维、安全制定相关标准和准则&#xff1b; 2、负责集团数据中心、核心设备、信息安全的管理和运维&#xff1b; 3、执行网络、服务器、核心交换机…

HTML开篇之安装VSvode(用记事本编辑HTML)

文章目录 前端开篇开篇知识点讲解1.HTML 结构1.1认识 HTML 标签1.2HTML 文件基本结构1.3标签层次结构1.4快速生成代码框架1.5用记事本写HTML1.6前端开发工具1.7下载vscode 及使用教学 大家好&#xff0c;我是晓星航。今天为大家带来的是 HTML 相关的讲解&#xff01;&#x1f6…

基于复旦微JFM7K325T FPGA的高性能PCIe总线数据预处理载板(100%国产化)

PCIE711是一款基于PCIE总线架构的高性能数据预处理FMC载板&#xff0c;板卡采用复旦微的JFM7K325T FPGA作为实时处理器&#xff0c;实现各个接口之间的互联。该板卡可以实现100%国产化。 板卡具有1个FMC&#xff08;HPC&#xff09;接口&#xff0c;1路PCIe x8主机接口&#x…

pytorch_神经网络构建2(数学原理)

文章目录 深层神经网络多分类深层网络反向传播算法优化算法动量算法Adam 算法 深层神经网络 分类基础理论: 交叉熵是信息论中用来衡量两个分布相似性的一种量化方式 之前讲述二分类的loss函数时我们使用公式-(y*log(y_)(1-y)*log(1-y_)进行误差计算 y表示真实值,y_表示预测值 …