MySQL的高级SQL语句

目录

一、高级SQL语句

1、select    查询表中一个或多个字段的数据

2、distinct    不显示重复的数据记录

3、where    有条件查询

4、and与or    且与或

5、in   显示在某个范围值内  的字段的信息

6、between      显示两个值范围内的数据记录

7、order  by     对字段进行排序

8、group  by    对字段进行分组汇总

9、having     用于过滤由group  by语句返回的记录集

10、like   模糊查询

11、别名        字段别名,表格别名

12、exists        用来测试内查询有没有产生任何结果

二、多表查询

内连接(inner  join)

左连接(left  join)

右连接(right  join)

联集  ( union  |  union  all )

取两个表无交集的值

1、取左表中存在,而右表中不存在的数据

2、取右表中存在,而左表中不存在的数据

三、函数

1、数学函数

2、聚合函数

3、字符串函数

四、视图

1、创建视图

2、删除视图

五、case语句及正则表达匹配

1、case语句

2、空值(NULL)与无值(“”)的区别

3、正则匹配

六、存储过程

1、存储过程的优点

2、创建存储过程

3、存储过程中的参数

1)IN输入参数

2)OUT输出参数

3)INOUT输入输出参数

4、删除存储过程

5、存储过程的控制语句

1)条件语句

2)循环语句


一、高级SQL语句

1、select    查询表中一个或多个字段的数据

语法:select   字段1,字段2,...  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 >200  and  sales <1000;


5、in   显示在某个范围值内  的字段的信息

语法:select   字段  from  表名  where  字段  in  (值1,值2,....);

例:select  store_name  from  store_info  where  store_name  ('Los Angeles','Houston');

6、between      显示两个值范围内的数据记录

语法:select  字段  from  表名  where  字段  between   值1  and   值2;

例:select  store_name,sales  from store_info  where  sales  between  300   and    1000;

7、order  by     对字段进行排序

默认升序 (asc) 的排序方式,使用desc实现降序排序

语法:select  字段   from   表名   [ where  条件 ]   order by   字段   asc|desc;

例:select   *  from  store_info  order  by  sales desc; 

8、group  by    对字段进行分组汇总

语法:select  字段  from 表名  group   by   字段;

例:select store_name,sum(sales),date from store_info group by store_name;

9、having     用于过滤由group  by语句返回的记录集

通俗来说,就是用来过滤出符合条件的group  by语句所返回的内容

语法:select  字段  from 表名  group  by  字段  having  条件表达式;        #条件表达式必须是使用函数的条件表达式

例: select store_name,sum(sales),date from store_info group by store_name having sum(sales) > 500;

10、like   模糊查询

使用通配符进行模糊查询

通配符

%:百分号表示零个、一个或多个字符

_:下划线表示单个字符

语法:select  字段  from  表名  where  字段  like  '模糊查询的内容';

例:select  store_name  from   store_info  where  store_name like  '_os%';

11、别名        字段别名,表格别名

语法:select  别名2.字段  [as]  别名1  from 表名  [as]  别名2;

例:select  A.store_name  name  from store_info as A ;

12、exists        用来测试内查询有没有产生任何结果

类似布尔值是否为真,如果有的话,系统就会执行外查询中的SQL语句。若是没有的话,那整个 SQL 语句就不会产生任何结果。

 语法:select  字段1  from   表1   where  exists  (select  字段2  from  表2  where  条件表达式 )

例:SELECT SUM(Sales) FROM Store_Info WHERE EXISTS (SELECT * FROM location WHERE Region = 'West');

二、多表查询

多表查询方式:内连接、左连接、右连接、联集

内连接(inner  join)

语法:select  *  from  表1  inner  join   表2  on  表1.字段=表2.字段

例:select  *  from  location A   inner join  store_info  B on  A.store_name=B.store_name;

左连接(left  join)

语法:select  *  from  表1  left  join   表2  on  表1.字段=表2.字段

例:select  *  from  location A   left  join  store_info  B on  A.store_name=B.store_name;

右连接(right  join)

语法:select  *  from  表1  right  join   表2  on  表1.字段=表2.字段

例:select  *  from  location A   right  join  store_info  B on  A.store_name=B.store_name;

联集  ( union  |  union  all )

语法:[SELECT 语句 1] UNION [SELECT 语句 2];

           [SELECT 语句 1] UNION ALL [SELECT 语句 2];

例:SELECT Store_Name FROM location UNION SELECT Store_Name FROM store_info;

例:SELECT Store_Name FROM location UNION ALL SELECT Store_Name FROM store_info;

取两个表无交集的值

1、取左表中存在,而右表中不存在的数据

语法:select   字段   from  左表  where  字段  not  in  (select  字段  from  右表)

如:select   store_name  from  location  where store_name not in (select  store_name from  store_info);

2、取右表中存在,而左表中不存在的数据

语法:select   字段   from  右表  where  字段  not  in  (select  字段  from  左表)

如:select   store_name  from  store_info  where store_name not in (select  store_name from  location);

三、函数

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

2、聚合函数

函数解释
avg()返回指定列的平均值

conut()

返回指定列中非 NULL 值的个数
min()返回指定列的最小值
max()返回指定列的最大值
sum()返回指定列的所有值之和

例1:SELECT avg(Sales) FROM store_info;

例2:SELECT count(Store_Name) FROM store_info;

例3:SELECT count(DISTINCT Store_Name) FROM store_info;

例4:SELECT max(Sales) FROM store_info;

例5:SELECT min(Sales) FROM store_info;

例6:SELECT sum(Sales) FROM store_info;

3、字符串函数

函数解释
trim()返回去除指定格式的值
concat(x,y)将提供的参数 x 和 y 拼接成一个字符串
substr(x,y)    获取从字符串 x 中的第 y 个位置开始的字符串,跟substring()函数作用相同
substr(x,y,z)获取从字符串 x 中的第 y 个位置开始长度为 z 的字符串
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 反转

trim()函数

语法:SELECT TRIM ([ [位置] [要移除的字符串] FROM ] 字符串);

#[位置]:的值可以为 LEADING (起头), TRAILING (结尾), BOTH (起头及结尾)。 
#[要移除的字符串]:从字串的起头、结尾,或起头及结尾移除的字符串。缺省时为空格。

例1:SELECT TRIM(LEADING 'Ne' FROM 'New York');

concat  ()  函数

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

例2:SELECT concat(Region, Store_Name) FROM location WHERE Store_Name = 'Boston';

例3:SELECT Region || ' ' || Store_Name FROM location WHERE Store_Name = 'Boston';

substr () 函数

例4:SELECT substr(Store_Name,3) FROM location WHERE Store_Name = 'Los Angeles';
例5:SELECT substr(Store_Name,2,4) FROM location WHERE Store_Name = 'New York';

length()  函数

例6:SELECT Region,length(Store_Name) FROM location;

replace  ()  函数

例7:SELECT REPLACE(Region,'ast','astern')FROM location;

四、视图

视图,可以被当作是虚拟表或存储查询。

视图跟表格的不同是,表格中有实际储存数据记录,而视图是建立在表格之上的一个架构,它本身并不实际储存数据记录。

临时表在用户退出或同数据库的连接断开后就自动消失了,而视图不会消失。
视图不含有数据,只存储它的定义,它的用途一般可以简化复杂的查询。比如你要对几个表进行连接查询,而且还要进行统计排序等操作,写SQL语句会很麻烦的,用视图将几个表联结起来,然后对这个视图进行查询操作,就和对一个表查询一样,很方便。

1、创建视图

语法:create  view   视图表名  as   select语句;

如:CREATE VIEW V_REGION_SALES AS SELECT A.Region REGION,SUM(B.Sales) SALES FROM location A INNER JOIN Store_Info B ON A.Store_Name = B.Store_Name GROUP BY REGION;

SELECT * FROM V_REGION_SALES;

2、删除视图

语法:drop  view  视图表名;

如:DROP VIEW V_REGION_SALES;

注意:在创建视图表时,后面的select语句所查询的字段原表中的字段时,视图表中的数据是可以修改的;
        若在创建视图表时,后面的select语句所查询的字段是通过聚合函数处理过的或被处理过的数据,视图表中的数据是不可以修改的。

五、case语句及正则表达匹配

1、case语句

case是 SQL 用来做为 IF-THEN-ELSE 之类逻辑的关键字

语法:

SELECT CASE ("字段名")
  WHEN "条件1" THEN "结果1"
  WHEN "条件2" THEN "结果2"
  ...
  [ELSE "结果N"]
  END
FROM "表名";

如: select store_name,case store_name
    -> when 'Los Angeles' then sales*2
    -> when 'Boston' then 2000
    -> else sales
    -> end
    -> "New Sales",date from store_info;

2、空值(NULL)与无值(“”)的区别

  • 无值的长度为 0,不占用空间的;而 NULL 值的长度是 NULL,是占用空间的。
  • IS NULL 或者 IS NOT NULL,是用来判断字段是不是为 NULL 或者不是 NULL,不能查出是不是无值的。
  • 无值的判断使用=''或者<>''来处理。<> 代表不等于。 
  • 在通过 count()指定字段统计有多少行数时,如果遇到 NULL 值会自动忽略掉,遇到无值会加入到记录中进行计算。

3、正则匹配

匹配模式描述
^

匹配文本的开始字符

‘^bd’ 匹配以 bd 开头的字符串

$

匹配文本的结束字符                       

 ‘qn$’ 匹配以 qn 结尾的字符串

.

匹配任何单个字符                      

 ‘s.t’ 匹配任何 s 和 t 之间有一个字符的字符串

*

匹配零个或多个在它前面的字符           

 ‘fo*t’ 匹配 t 前面有任意个 o

+

匹配前面的字符 1 次或多次              

 ‘hom+’ 匹配以 ho 开头,后面至少一个m 的字符串

字符串

匹配包含指定的字符串                  

‘clo’ 匹配含有 clo 的字符串

p1|p2

匹配 p1 或 p2                           

 ‘bg|fg’ 匹配 bg 或者 fg

[abcd]

匹配字符集合中的任意一个字符           

 ‘[abcd]’ 匹配 a 或者 b 或者 c或者d

[^abcd]

匹配不在括号中的任何字符               

 ‘[^abcd]’ 匹配不包含 a 或者 b或者 c或者d 的字符串

{n}

匹配前面的字符串 n 次                   

 ‘g{2}’ 匹配含有 2 个 g 的字符串

{n,m}

匹配前面的字符串至少 n 次,至多m 次      

 ‘f{1,3}’ 匹配 f 最少 1 次,最多 3 次

语法:select  字段  from  表名  where  字段  regexp  {模式};

如:SELECT * FROM Store_Info WHERE Store_Name REGEXP 'os';
SELECT * FROM Store_Info WHERE Store_Name REGEXP '^[A-G]';
SELECT * FROM Store_Info WHERE Store_Name REGEXP 'Ho|Bo';

六、存储过程

存储过程是一组为了完成特定功能的SQL语句集合。

存储过程在使用过程中是将常用或者复杂的工作预先使用SQL语句写好并用一个指定的名称存储起来,这个过程经编译和优化后存储在数据库服务器中。当需要使用该存储过程时,只需要调用它即可。存储过程在执行上比传统SQL速度更快、执行效率更高。

1、存储过程的优点

1、执行一次后,会将生成的二进制代码驻留缓冲区,提高执行效率
2、SQL语句加上控制语句的集合,灵活性高
3、在服务器端存储,客户端调用时,降低网络负载
4、可多次重复被调用,可随时修改,不影响客户端调用
5、可完成所有的数据库操作,也可控制数据库的信息访问权限

2、创建存储过程

#首先使用delimiter修改语句的结束符,可以是$$,##,!!等自定义的符号delimiter  $$#其次开始创建存储过程create   procedure   存储过程名()->begin        #关键字begin开始->SQL语句序列->end$$        #存储过程的结束语句#最后再将SQL的语句结束符改回来成分号“;”delimiter  ;#调用存储过程call   存储过程名#查看存储过程show  create  peocedure  存储过程名;或show  procedure  status  存储过程名\G

如:

delimiter  ##

create  procedure  proc1()

->begin

->create  table  t1 (id int,name  varchar(20),age int,primary key(id));

->insert into t1 values(1,'张三',18);

->insert into t1 values(2,'李四',19);

->insert into t1 values(3,'王五',20);

->end##

delimiter ;

call proc1();

3、存储过程中的参数

IN 输入参数:表示调用者向过程传入值(传入值可以是字面量或变量)
OUT 输出参数:表示过程向调用者传出值(可以返回多个值)(传出值只能是变量)
INOUT 输入输出参数:既表示调用者向过程传入值,又表示过程向调用者传出值(值只能是变量)

1)IN输入参数

实例:

delimiter $$

create  procedure  proc2(in  inname  char(16))

->begin

->select  *  from  store_info where store_name=inname;

->end$$

delimiter ;

call proc2('Boston');

2)OUT输出参数

实例:

delimiter $$
mysql> create procedure prco3(in inname varchar(20),out outage int)
    -> begin
    -> select age into outage from t1 where inname=name;
    -> end$$
delimiter ;
call proc3('李四',@age);
select @age;

3)INOUT输入输出参数

实例:

delimiter $$

mysql>creater  procedure  proc4(inout  inage  int)

         ->begin

         ->select  age into inage from t1 where age>inage;

         ->end$$

delimiter ;

set @age=19;

call  proc4(@age);

seect @age;

4、删除存储过程

语法:drop  procedure  if  exists  存储过程名;

#仅当存在时删除,不添加 IF EXISTS 时,如果指定的过程不存在,则产生一个错误

实例:

drop   procedure if exists  prco3;

5、存储过程的控制语句

1)条件语句

if-then-else....end  if

实例:
DELIMITER $$  
CREATE PROCEDURE proc6(IN pro int)  
-> begin 
-> declare var int;  
-> set var=pro*2;   
-> if var>=10 then 
-> update t set id=id+1;  
-> else 
-> update t set id=id-1;  
-> end if;  
-> end $$delimiter ;
call proc6(6);
select * from t;

2)循环语句

while ... end while

实例:
delimiter $$
create procedure proc7()
->begin
->declare var int(10);
->set var=0;
->create table t2(id int,name char(10));
->while var <5 
->do
->insert into t2 values(var,concat('a',var));
->set var=var+1;
->end while;
->end $$delimiter ;
call proc7();
select * from t2;

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

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

相关文章

ChatGLM 实现一个BERT

前言 本文包含大量源码和讲解,通过段落和横线分割了各个模块,同时网站配备了侧边栏,帮助大家在各个小节中快速跳转,希望大家阅读完能对BERT有深刻的了解。同时建议通过pycharm、vscode等工具对bert源码进行单步调试,调试到对应的模块再对比看本章节的讲解。 涉及到的jupyt…

网络安全:保护你的系统

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

logback异步appender日志源码详解

背景&#xff1a; 日常打印日志时&#xff0c;使用logback的异步写日志几乎是标准的配置方式&#xff0c;本文从源码上看看异步写日志的整个流程 异步Appender日志 一般日志的配置如下所示 appender(“ASYNC-LOG”, AsyncAppender) { neverBlock true queueSize 10000 } 这…

【chrome 插件】AdGuard 广告拦截器:安全清爽的互联网浏览体验

AdGuard 广告拦截器介绍 基本信息 AdGuard 是一款功能强大的广告拦截程序&#xff0c;它可以帮助用户在浏览网页时过滤掉网站中烦人的广告和恶意弹窗&#xff0c;提升获取信息的效率&#xff0c;同时&#xff0c;作为一款 Chrome 插件&#xff0c;AdGuard 提供了简单易用的界…

除法求值00

题目链接 除法求值 题目描述 注意点 Ai, Bi, Cj, Dj 由小写英文字母与数字组成输入总是有效的&#xff0c;可以假设除法运算中不会出现除数为 0 的情况&#xff0c;且不存在任何矛盾的结果未在等式列表中出现的变量是未定义的&#xff0c;因此无法确定它们的答案 解答思路 …

Linux内核源码分析 (B.4) 深度剖析 Linux 伙伴系统的设计与实现

Linux内核源码分析 (B.4) 深度剖析 Linux 伙伴系统的设计与实现 文章目录 1\. 伙伴系统的核心数据结构2\. 到底什么是伙伴3\. 伙伴系统的内存分配原理4\. 伙伴系统的内存回收原理5\. 进入伙伴系统的前奏5.1 获取内存区域 zone 里指定的内存水位线5.2 检查 zone 中剩余内存容量…

HelpLook全新升级!定制AI问答机器人,企业内容中心焕新

一直以来&#xff0c;企业都在努力解决内外部“企业知识管理”问题&#xff1a;从纸质手册发放&#xff0c;转线上电子文档传阅(pdf/ppt/word等)&#xff0c;再到整理客户常见问题(FAQ)和内部知识库(wiki)&#xff0c;但始终没有找到一套完整方案将“企业知识”很好地集中管理及…

Flutter与Native通信原理剖析与实践

通信原理 我们分几种场景来介绍Flutter和Native之间的通信。 Native发送数据给FlutterFlutter发送数据给NativeFlutter发送数据给Native&#xff0c;然后Native回传数据给Flutter Flutter与Native通信机制 在讲解Flutter与Native之间是如何传递数据之前&#xff0c;我们先了…

PostgreSQL16源码包编译安装

一、安装环境 操作系统&#xff1a;CentOS Linux release 7.8.2003 (Core) PostgreSQL版本&#xff1a;16 服务器IP地址&#xff1a;192.168.0.244 Firewalld关闭、selinux关闭 笔者本次选用最新v16版本进行部署 二、pg数据库安装包下载 下载地址&#xff1a;https://www.po…

什么是IoT数字孪生?

数字孪生是资产或系统的实时虚拟模型&#xff0c;它使用来自连接的物联网传感器的数据来创建数字表示。数字孪生允许您从任何地方实时监控设备、资产或流程。数字孪生用于多种目的&#xff0c;例如分析性能、监控问题或在实施之前运行测试。从物联网数字孪生中获得的见解使用户…

操作系统备考学习 day3 (2.1.1 - 2.1.6)

操作系统备考学习 day3 二、进程与线程2.1 进程与线程2.1.1 进程的概念和特征2.1.2 进程的状态与转换2.1.3 进程的组织2.1.4 进程控制2.1.5 进程间通信&#xff08;IPC&#xff09;2.1.6 线程和多线程模型 二、进程与线程 2.1 进程与线程 2.1.1 进程的概念和特征 进程&#…

怎样获取某个文件的public方法个数

背景&#xff1a;idea 提供的list可以查看所有的构造方法&#xff0c;但是无法直接告诉我准确的数目&#xff0c;于是写了以下一个单独的类 import java.lang.reflect.Method; import java.lang.reflect.Modifier;public class MyPublicMethodCounter {public static void mai…

flink集群与资源@k8s源码分析-集群

0 介绍 本文是flink集群与资源@k8s源码分析系列的第二篇-集群 1 场景 下面详细分析各用例 2 启动k8s集群 k8s集群支持session和application模式,job模式将会被废弃,本文分析session模式集群 Configuration作为配置容器,几乎所有的构建需要从配置类获取配置项,这里不显示…

算法通关村第14关【黄金】| 数据流的中位数

思路&#xff1a;使用一个小根堆一个大根堆来找中位数 小根堆保存较大的一半数字&#xff0c;大根堆保存较小的一半数字 奇数queMin的队头即为中位数&#xff0c;偶数queMin和queMax队头相加/2为中位数 初始状态&#xff1a; queMin: [] queMax: [] 添加数字 1&#xff1a; …

java面试题基础第七天

一、java面试题第七天 1.throw和throws的区别&#xff1f; throw&#xff1a; 用于抛出一个异常对象throws&#xff1a;写在方法体上面&#xff0c;将方法体里面的异常&#xff0c;抛给上层 2. 通过故事讲清楚NIO 下面通过一个例子来讲解下。 假设某银行只有10个职员。该银…

stm32学习-芯片系列/选型

【03】STM32HAL库开发-初识STM32 | STM概念、芯片分类、命名规则、选型 | STM32原理图设计、看数据手册、最小系统的组成 、STM32IO分配_小浪宝宝的博客-CSDN博客  STM32&#xff1a;ST是意法半导体&#xff0c;M是MCU/MPU&#xff0c;32是32位。  ST累计推出了&#xff1a…

buuctf web [极客大挑战 2019]LoveSQL

又是这样的界面&#xff0c;这糟糕的熟悉感&#xff0c;依旧使用上题套路 用户名&#xff1a; admin or 11# 密码&#xff1a; 1 有一串很像flag的字符&#xff0c;但是很可惜&#xff0c;这不是flag 看了一眼源代码&#xff0c;没有可以跳转的页面 要换个思路了&#xff0c…

(二十九)大数据实战——kafka集群节点服役与退役案例实战

前言 本节内容是关于kafka集群节点的服役与退役&#xff0c;从而实现kafka集群的缩容与扩容。在开始本节内容之前&#xff0c;我们要预先安装好kafka集群&#xff0c;并准备一台空余的服务器用来完成我们扩容与缩容的案例。关于kafka集群的安装内容这里不在赘述&#xff0c;相…

Python Web 开发常见的100个问题.pdf

Python被广泛认为是一种容易学习和上手的编程语言&#xff0c;因此对于初学者和有经验的开发者都非常友好。这一特点使得Python成为了许多开发者入门Web开发的首选语言。 在Python Web开发中&#xff0c;开发者们通常会遇到各种各样的问题和挑战。现在我们为大家准备了学习路线…

PostgreSQL快速入门 与MySQL语法比较

开篇 本文可帮助具有MySQL基础的小伙伴对PostgreSQL做一个快速的入门&#xff0c;通过语法之间的差异对比&#xff0c;降低学习成本&#xff0c;同样都是数据库&#xff0c;正所谓触类旁通。 模式的概念 模式&#xff08;Schema&#xff09;表示数据库中的逻辑容器&#xff…