MySQL 高级(进阶) SQL 语句

目录

一、实验环境准备

二、MySQL高阶查询

1、语句与命令

2、实验实操

三、MySQL函数

1、语句与命令

2、实验操作


一、实验环境准备

#创建两个数据表,为实验提供环境:
use kgc;   #选择数据库,有则直接使用 无则按照以下步骤自建即可。
表一:
create table location (Region char(20),Store_Name char(20));
insert into location values('East','Boston');
insert into location values('East','New York');
insert into location values('West','Los Angeles');
insert into location values('West','Houston');location 表格
+----------+--------------+ 
| Region   | Store_Name   |
|----------+--------------|
| East     | Boston       |
| East     | New York     |
| West     | Los Angeles  |
| West     | Houston      |
+----------+--------------+表二:
create table store_info (Store_Name char(20),Sales int(10),Date char(10));
insert into store_info values('Los Angeles','1500','2020-12-05');
insert into store_info values('Houston','250','2020-12-07');
insert into store_info values('Los Angeles','300','2020-12-08');
insert into store_info values('Boston','700','2020-12-08');Store_Info 表格
+--------------+---------+------------+
| Store_Name   |   Sales | Date       |
|--------------+---------+------------|
| Los Angeles  |    1500 | 2020-12-05 |
| Houston      |     250 | 2020-12-07 |
| Los Angeles  |     300 | 2020-12-08 |
| Boston       |     700 | 2020-12-08 |
+--------------+---------+------------+

二、MySQL高阶查询

1、语句与命令

1、---- select ----显示表格中一个或数个字段的所有数据记录
语法:select "字段" from "表名";
select Store_Name from Store_Info;2、---- distinct ----不显示重复的数据记录
语法:select distinct "字段" from "表名";
select distinct store_name from store_info;3、---- where ----有条件查询
语法:select "字段" from "表名" where "条件";
select store_name from store_info where sales > 1000;4、---- and or ----且 或
语法:select "字段" from "表名" where "条件1" {[and|or] "条件2"}+ ;
select store_name from store_info where sales > 1000 or (sales < 500 and sales > 200);5、---- in ----显示已知的值的数据记录
语法:select "字段" from "表名" where "字段" in ('值1', '值2', ...);
select * from store_info where store_name in ('los angeles','houstton');6、---- between ----显示两个值范围内的数据记录
语法:select "字段"from "表名" where "字段" between '值1' and '值2';
select * from store_info where date between '2020-12-06' and '20200-12-10';7、---- 通配符 ----通常通配符都是跟 like 一起使用的
% :百分号表示零个、一个或多个字符
_ :下划线表示单个字符1)'A_Z':所有以 'A' 起头,另一个任何值的字符,且以 'Z' 为结尾的字符串。例如,'ABZ' 和 'A2Z' 都符合这一个模式,而 'AKKZ' 并不符合 (因为在 A 和 Z 之间有两个字符,而不是一个字符)。2)'ABC%': 所有以 'ABC' 起头的字符串。例如,'ABCD' 和 'ABCABC' 都符合这个模式。3)'%XYZ': 所有以 'XYZ' 结尾的字符串。例如,'WXYZ' 和 'ZZXYZ' 都符合这个模式。4)'%AN%': 所有含有 'AN'这个模式的字符串。例如,'LOS ANGELES' 和 'SAN FRANCISCO' 都符合这个模式。5)'_AN%':所有第二个字母为 'A' 和第三个字母为 'N' 的字符串。例如,'SAN FRANCISCO' 符合这个模式,而 'LOS ANGELES' 则不符合这个模式。例:---- like ----匹配一个模式来找出我们要的数据记录
语法:select "字段" from "表名" where "字段" like {模式};
select * from store_info where store_name like '%os%';8、---- order by ----按关键字排序
语法:select "字段" from "表名" [where "条件"] order by "字段" [asc, desc];
#asc 是按照升序进行排序的,是默认的排序方式。
#desc 是按降序方式进行排序。
select store_name,sales,date from store_info order by sales desc;

2、实验实操

1、---- select ----显示表格中一个或数个字段的所有数据记录
语法:select "字段" from "表名";
select Store_Name from Store_Info;

2、---- distinct ----不显示重复的数据记录
语法:select distinct "字段" from "表名";
select distinct store_name from store_info;

3、---- where ----有条件查询
语法:select "字段" from "表名" where "条件";
select store_name from store_info where sales > 1000;

4、---- and or ----且 或
语法:select "字段" from "表名" where "条件1" {[and|or] "条件2"}+ ;
select store_name from store_info where sales > 1000 or (sales < 500 and sales > 200);

5、---- in ----显示已知的值的数据记录
语法:select "字段" from "表名" where "字段" in ('值1', '值2', ...);
select * from store_info where store_name in ('los angeles','houstton');

6、---- between ----显示两个值范围内的数据记录
语法:select "字段"from "表名" where "字段" between '值1' and '值2';
select * from store_info where date between '2020-12-06' and '20200-12-10';

7、---- 通配符 ----通常通配符都是跟 like 一起使用的
% :百分号表示零个、一个或多个字符
_ :下划线表示单个字符

1)'A_Z':所有以 'A' 起头,另一个任何值的字符,且以 'Z' 为结尾的字符串。例如,'ABZ' 和 'A2Z' 都符合这一个模式,而 'AKKZ' 并不符合 (因为在 A 和 Z 之间有两个字符,而不是一个字符)。

2)'ABC%': 所有以 'ABC' 起头的字符串。例如,'ABCD' 和 'ABCABC' 都符合这个模式。

3)'%XYZ': 所有以 'XYZ' 结尾的字符串。例如,'WXYZ' 和 'ZZXYZ' 都符合这个模式。

4)'%AN%': 所有含有 'AN'这个模式的字符串。例如,'LOS ANGELES' 和 'SAN FRANCISCO' 都符合这个模式。

5)'_AN%':所有第二个字母为 'A' 和第三个字母为 'N' 的字符串。例如,'SAN FRANCISCO' 符合这个模式,而 'LOS ANGELES' 则不符合这个模式。

例:---- like ----匹配一个模式来找出我们要的数据记录
语法:select "字段" from "表名" where "字段" like {模式};
select * from store_info where store_name like '%os%';

8、---- order by ----按关键字排序
语法:select "字段" from "表名" [where "条件"] order by "字段" [asc, desc];
#asc 是按照升序进行排序的,是默认的排序方式。

#desc 是按降序方式进行排序。
select store_name,sales,date from store_info order by sales desc;

三、MySQL函数

1、语句与命令

#数学函数:
abs(x)				返回 x 的绝对值
rand()				返回 0 到 1 的随机数
mod(x,y)			返回 x 除以 y 以后的余数
power(x,y)			返回 x 的 y 次方
round(x)			返回离 x 最近的整数
round(x,y)			保留 x 的 y 位小数四舍五入后的值
sqrt(x)				返回 x 的平方根
truncate(x,y)		返回数字 x 截断为 y 位小数的值
ceil(x)				返回大于或等于 x 的最小整数
floor(x)			返回小于或等于 x 的最大整数
greatest(x1,x2...)	返回集合中最大的值,也可以返回多个字段的最大的值
least(x1,x2...)		返回集合中最小的值,也可以返回多个字段的最小的值函数输出值的效果展示:
select abs(-1), rand(), mod(5,3), power(2,3), round(1.89);select round(1.8937,3), truncate(1.235,2), ceil(5.2), floor(2.1), least(1.89,3,6.1,2.1);#聚合函数:
avg()				返回指定列的平均值
count()				返回指定列中非 NULL 值的个数
max()				返回指定列的最大值
min()				返回指定列的最小值
sum(x)				返回指定列的所有值之和聚合函数运用:
select avg(sales) from store_info;
#返回指定列的平均值select count(store_name) from store_info;
#返回指定列中非NULL 值的个数
select count(distinct store_name) from store_info;
#返回指定列中非重复,非NULL 值的个数select max(sales) from store_info;
#返回指定列的最大值select min(sales) from store_info;
#返回指定列的最小值select sum(sales) from store_info;
#返回指定列的所有值之和City 表格 
+----------+| name     |
| -------- |
| beijing  |
| nanjing  |
| shanghai |
| <null>   |
| <null>   |+----------+
select count(name) from city;
select count(*) from city;
#count(列名) 只包括列名那一列的行数,在统计结果的时候,会忽略列值为 NULL 的行
#count(*) 包括了所有的列的行数,在统计结果的时候,不会忽略列值为 NULL 的行#字符串函数:
concat(x,y)		将提供的参数 x 和 y 拼接成一个字符串
substr(x,y)		获取从字符串x中的第y个位置开始的字符串,跟substring()函数作用相同
substr(x,y,z)	获取从字符串 x 中的第 y 个位置开始长度为 z 的字符串
trim()			返回去除指定格式的值
length(x)		返回字符串 x 的长度
replace(x,y,z)	将字符串 z 替代字符串 x 中的字符串 y
upper(x)		将字符串 x 的所有字母变成大写字母
lower(x)		将字符串 x 的所有字母变成小写字母
left(x,y)		返回字符串 x 的前 y 个字符
right(x,y)		返回字符串 x 的后 y 个字符
repeat(x,y)		将字符串 x 重复 y 次
space(x)		返回 x 个空格
strcmp(x,y)		比较 x 和 y,返回的值可以为-1,0,1
reverse(x)		将字符串 x 反转select concat(region,store_name) from location where store_name = 'boston';
#将参数 region 和 store_name 拼接成一个字符串select region || '' || store_name from location where store_name = 'boston';
#如sql_mode开启了PIPES_AS_CONCAT,"||"视为字符串的连接操作符而非或运算符,和字符串的拼接函数Concat相类似,这和Oracle数据库使用方法一样的select substr(store_name,3) from location where store_name = 'Los Angeles';
#获取字符串store_name中的第 3 个位置开始的字符串
select substr(store_name,2,4) from location where store_name ame = 'New York';
#获取字符串store_name中的第 2 个位置开始长度为 4 的字符串select trim ([ [位置] [要移除的字符串] from ] 字符串);
#[位置]:的值可以为 leading (起头), tralling (结尾), both (起头及结尾)。 
#[要移除的字符串]:从字串的起头、结尾,或起头及结尾移除的字符串。缺省时为空格。
select trim(leading 'ne' from 'new york');
#去除 new york 字符串中的开头 ne 字符select region,length(store_name) from location;
#显示字符串 store_name 的长度select replace(region,'ast','astern')from location;
#将字符串 region 替代字符串 'ast' 中的字符串'astern'

2、实验操作

#数学函数:
abs(x)                返回 x 的绝对值
rand()                返回 0 到 1 的随机数
mod(x,y)            返回 x 除以 y 以后的余数
power(x,y)            返回 x 的 y 次方
round(x)            返回离 x 最近的整数
round(x,y)            保留 x 的 y 位小数四舍五入后的值
sqrt(x)                返回 x 的平方根
truncate(x,y)        返回数字 x 截断为 y 位小数的值
ceil(x)                返回大于或等于 x 的最小整数
floor(x)            返回小于或等于 x 的最大整数
greatest(x1,x2...)    返回集合中最大的值,也可以返回多个字段的最大的值
least(x1,x2...)        返回集合中最小的值,也可以返回多个字段的最小的值

函数输出值的效果展示:
select abs(-1), rand(), mod(5,3), power(2,3), round(1.89);

select round(1.8937,3), truncate(1.235,2), ceil(5.2), floor(2.1), least(1.89,3,6.1,2.1);


 

#聚合函数:
avg()                返回指定列的平均值
count()                返回指定列中非 NULL 值的个数
max()                返回指定列的最大值
min()                返回指定列的最小值
sum(x)                返回指定列的所有值之和

聚合函数运用:
select avg(sales) from store_info;
#返回指定列的平均值

select count(store_name) from store_info;
#返回指定列中非NULL 值的个数

select count(distinct store_name) from store_info;
#返回指定列中非重复,非NULL 值的个数

select max(sales) from store_info;
#返回指定列的最大值

select min(sales) from store_info;
#返回指定列的最小值

select sum(sales) from store_info;
#返回指定列的所有值之和


City 表格 
+----------+

| name     |
| -------- |
| beijing  |
| nanjing  |
| shanghai |
| <null>   |
| <null>   |

+----------+
select count(name) from city;
select count(*) from city;

#count(列名) 只包括列名那一列的行数,在统计结果的时候,会忽略列值为 NULL 的行
#count(*) 包括了所有的列的行数,在统计结果的时候,不会忽略列值为 NULL 的行

#字符串函数:
concat(x,y)        将提供的参数 x 和 y 拼接成一个字符串
substr(x,y)        获取从字符串x中的第y个位置开始的字符串,跟substring()函数作用相同
substr(x,y,z)    获取从字符串 x 中的第 y 个位置开始长度为 z 的字符串
trim()            返回去除指定格式的值
length(x)        返回字符串 x 的长度
replace(x,y,z)    将字符串 z 替代字符串 x 中的字符串 y
upper(x)        将字符串 x 的所有字母变成大写字母
lower(x)        将字符串 x 的所有字母变成小写字母
left(x,y)        返回字符串 x 的前 y 个字符
right(x,y)        返回字符串 x 的后 y 个字符
repeat(x,y)        将字符串 x 重复 y 次
space(x)        返回 x 个空格
strcmp(x,y)        比较 x 和 y,返回的值可以为-1,0,1
reverse(x)        将字符串 x 反转

select concat(region,store_name) from location where store_name = 'boston';
#将参数 region 和 store_name 拼接成一个字符串

select region || '' || store_name from location where store_name = 'boston';
#如sql_mode开启了PIPES_AS_CONCAT,"||"视为字符串的连接操作符而非或运算符,和字符串的拼接函数Concat相类似,这和Oracle数据库使用方法一样的

select substr(store_name,3) from location where store_name = 'Los Angeles';
#获取字符串store_name中的第 3 个位置开始的字符串

select substr(store_name,2,4) from location where store_name ame = 'New York';
#获取字符串store_name中的第 2 个位置开始长度为 4 的字符串

select trim ([ [位置] [要移除的字符串] from ] 字符串);
#[位置]:的值可以为 leading (起头), tralling (结尾), both (起头及结尾)。 
#[要移除的字符串]:从字串的起头、结尾,或起头及结尾移除的字符串。缺省时为空格。
select trim(leading 'ne' from 'new york');
#去除 new york 字符串中的开头 ne 字符

select region,length(store_name) from location;
#显示字符串 store_name 的长度

select replace(region,'ast','astern')from location;
#将字符串 region 替代字符串 'ast' 中的字符串'astern'

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

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

相关文章

WPF+Halcon 培训项目实战(8-9):WPF+Halcon初次开发

文章目录 前言相关链接项目专栏运行环境匹配图片WPF Halcon组件HSmartWindowControlWPF绑定读取图片运行代码运行结果 抖动问题解决运行结果 绘制矩形绘制图像会消失 绘制对象绑定事件拖动事件 前言 为了更好地去学习WPFHalcon&#xff0c;我决定去报个班学一下。原因无非是想…

nginx安装和配置

目录 1.安装 2.配置 3.最小配置说明 4. nginx 默认访问路径 1.安装 使用 epel 源安装 先安装 yum 的扩展包 yum install epel-release -y 再安装 nginx yum install nginx -y 在启动nginx 前先关闭防火墙 systemctl stop firewalld 取消防火墙开机自启 systemctl di…

Self-attention学习笔记(Self Attention、multi-head self attention)

李宏毅机器学习Transformer Self Attention学习笔记记录一下几个方面的内容 1、Self Attention解决了什么问题2、Self Attention 的实现方法以及网络结构Multi-head Self Attentionpositional encoding 3、Self Attention 方法的应用4、Self Attention 与CNN以及RNN对比 1、Se…

基于grpc从零开始搭建一个准生产分布式应用(8) - 01 - 附:GRPC公共库源码

开始前必读&#xff1a;​​基于grpc从零开始搭建一个准生产分布式应用(0) - quickStart​​ common包中的源码&#xff0c;因后续要用所以一次性全建好了。 一、common工程完整结构 二、引入依赖包 <?xml version"1.0" encoding"UTF-8"?> <p…

【linux】cat的基本使用

cat是一个常用的命令&#xff0c;用来显示文本的内容&#xff0c;合并和创建文本文件 类似命令还有显示文件开头的内容&#xff1a; 【linux】head的用法 输出文件开头的内容-CSDN博客 显示文件末尾的内容&#xff1a; 【linux】tail的基本使用-CSDN博客 当我们想到了想要…

Zookeeper-Zookeeper选举源码

看源码方法&#xff1a; 1、先使用&#xff1a;先看官方文档快速掌握框架的基本使用 2、抓主线&#xff1a;找一个demo入手&#xff0c;顺藤摸瓜快速静态看一遍框架的主线源码&#xff0c;画出源码主流程图&#xff0c;切勿一开始就陷入源码的细枝末节&#xff0c;否则会把自…

Primavera Unifier 项目控制延伸:Phase Gate理论:3/3

继续上一篇阶段Gate的具体内容 https://campin.blog.csdn.net/article/details/127827681https://campin.blog.csdn.net/article/details/127827681 阶段 3 研发 前述阶段的计划和安排都要在研发阶段执行起来&#xff0c;同时&#xff0c;最重要的产品设计和开发部分也需要在…

系统学习Python——装饰器:函数装饰器-[对方法进行装饰:基础知识]

分类目录&#xff1a;《系统学习Python》总目录 我们在前面的文章中编写了第一个基于类的tracer函数装饰器的时候&#xff0c;我们简单地假设它也应该适用于任何方法一一一被装饰的方法应该同样地工作&#xff0c;并且自带的self实例参数应该直接包含在*args的前面。但这一假设…

计算机基础面试题 |04.精选计算机基础面试题

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…

python打开文件的方式比较

open(addr,w) 打开之后文件无论以前有什么&#xff0c;打开后都要清空 /// open(addr,r) 文件打开后&#xff0c;不删除以前内容

多人协同开发git flow,创建初始化项目版本

文章目录 多人协同开发git flow&#xff0c;创建初始化项目版本1.gitee创建组织模拟多人协同开发2.git tag 打标签3.git push origin --tags 多人协同开发git flow&#xff0c;创建初始化项目版本 1.gitee创建组织模拟多人协同开发 组织中新建仓库 推送代码到我们组织的仓库 2…

STM32与TB6612电机驱动器的基础入门教程

TB6612是一款常用的双路直流电机驱动芯片&#xff0c;适用于小型机器人以及其他需要控制电机方向和转速的应用。在STM32微控制器的配合下&#xff0c;可以实现对TB6612电机驱动器的控制&#xff0c;进而实现电机的控制。本文将带领读者一步步了解如何搭建基于STM32与TB6612的电…

我从来不理解JavaScript闭包,但我用了它好多年

前言 &#x1f4eb; 大家好&#xff0c;我是南木元元&#xff0c;热衷分享有趣实用的文章&#xff0c;希望大家多多支持&#xff0c;一起进步&#xff01; &#x1f345; 个人主页&#xff1a;南木元元 你是否学习了很久JavaScript但还没有搞懂闭包呢&#xff1f;今天就来聊一下…

SpringBoot解决前后端分离跨域问题:状态码403拒绝访问

最近在写和同学一起做一个前后端分离的项目&#xff0c;今日开始对接口准备进行 登录注册 的时候发现前端在发起请求后&#xff0c;抓包发现后端返回了一个403的错误&#xff0c;解决了很久发现是【跨域问题】&#xff0c;第一次遇到&#xff0c;便作此记录✍ 异常描述 在后端…

Java---网络编程

文章目录 1. 网络编程概述2. InetAddress3. 端口和协议4. Java网络API5. URL6. URLConnection类 1. 网络编程概述 1. 计算机网络&#xff1a;是指将地理位置不同的具有独立功能的多台计算机及其外部设备&#xff0c;通过通信线路连接起来&#xff0c;在网络操作系统、网络管理软…

2024年Mac专用投屏工具AirServer 7 .27 for Mac中文版

AirServer 7 .27 for Mac中文免费激活版是一款Mac专用投屏工具&#xff0c;能够通过本地网络将音频、照片、视频以及支持AirPlay功能的第三方App&#xff0c;从 iOS 设备无线传送到 Mac 电脑的屏幕上&#xff0c;把Mac变成一个AirPlay终端的实用工具。 目前最新的AirServer 7.2…

Matlab技巧[绘画逻辑分析仪产生的数据]

绘画逻辑分析仪产生的数据 逻分上抓到了ADC数字信号,一共是10Bit,12MHZ的波形: 这里用并口协议已经解析出数据: 导出csv表格数据(这个数据为补码,所以要做数据转换): 现在要把这个数据绘制成波形,用Python和表格直接绘制速度太慢了,转了一圈发现MATLAB很好用,操作方法如下:…

逗号表达式与赋值表达式

逗号表达式和赋值表达式是C语言中常用的表达式类型。它们可以用于各种目的&#xff0c;包括计算和评估表达式、初始化变量、为函数调用提供参数以及将值分配给变量。 逗号表达式 逗号表达式允许在单个语句中计算和评估多个表达式。逗号分隔每个表达式&#xff0c;并且表达式从…

Spring Cloud Gateway + Nacos 灰度发布

前言 本文将会使用 SpringCloud Gateway 网关组件配合 Nacos 实现灰度发布&#xff08;金丝雀发布&#xff09; 环境搭建 创建子模块服务提供者 provider&#xff0c;网关模块 gateway 父项目 pom.xml 配置 <?xml version"1.0" encoding"UTF-8"?…

阿里云服务器开放端口Oracle 1521方法教程

阿里云服务器ECS端口是在安全组设置的&#xff0c;Oracle数据库1521端口号开放是在安全组中添加规则来实现的&#xff0c;阿里云服务器网aliyunfuwuqi.com来详细说下阿里云服务器开放Oracle 1521端口方法教程&#xff1a; 阿里云服务器开放Oracle 1521端口 在阿里云服务器ECS…