当前位置: 首页 > news >正文

MySQL数据库高阶语句②

目录

一.子查询与多表查询

1.子查询

2.update子查询

3.多表查询

4.delete子查询

5.exists关键字也用于子查询

6.结果集

二.MySQL视图

1.定义

2.作用场景

3.视图与表的区别与联系

(1)区别

①视图是已经编译好的sql语句。而表不是

②视图没有实际的物理记录。而表有。show table status\G

③表只用物理空间而视图不占用物理空间,视图只是逻辑概念的存在,表可以及时对它进行修改,但视图只能有创建的语句来修改

④视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些SQL语句的集合。从安全的角度说,视图可以不给用户接触数据表,从而不知道表结构。

⑤表属于全局模式中的表,是实表;视图属于局部模式的表,是虚表。

⑥视图的建立和删除只影响视图本身,不影响对应的基本表。(但是更新视图数据,是会影响到基本表的)

(2)联系

4.创建视图

5.修改视图数据

6.更改源表数据

三.NULL值


一.子查询与多表查询

子查询也被称作为内查询或者嵌套查询,是指在一个查询语句里面还嵌套着另一个查询语句。子查询语句是先于主查询语句被执行的,其结果作为外层的条件返回给主查询进行子阿姨不得查询过滤。

PS: 子语句可以与主语句所查询的表相同,也可以是不同表相同表实例:select name,score from info where id in (select id from info where score >80);
主语句:select name,score from info where id;
子语句(集合):select id from info where score >80;
PS:子语句中的sql语句是为了最后过滤出一个结果集,用于主语句的判断条件
** in:将主表和字表关联、连接的语法

1.子查询

select name,age from ky35 where id in (select id from ky35 where age>20);

2.update子查询

update info set age=17 where id in (select * from ky35 where id =4);

3.多表查询

select id,name,score from info where id in(select id from ky35);

子查询不仅可以在select语句中使用,在inert、update、delete中也可以同样适用。在嵌套的时候,子查询内部还可以再次嵌套新的子查询,也就是说可以多层嵌套。

语法:<表达式> 【not】 IN <子查询> ;

当表达式与子查询返回的结果集中的某个值相等时,返回true,否则返回false。若启用了not关键字,则返回值相反。需要注意的是,子查询只能返回一列数据,如果需求比较复杂,一列解决不了问题,可以使用多层嵌套的方式来应对,多数情况下,子查询都是与select语句一起使用的。

4.delete子查询

删除分数大于等于80的记录
delete from info where id in (select id where score>80)

注意:在IN前面还可以添加not,其作用于IN相反,表示否定(即不在子查询的结果集里面)

删除分数不大于等于80的记录
delete from info where id not in (select id where score>80)

5.exists关键字也用于子查询

这个关键字在子查询时,主要用于判断子查询的结果集是否为空。如果不为空, 则返回 TRUE;反之,则返回 FALSE

查询如果存在分数等于80的记录则计算info的字段数
select count(*) number from t1 where exists (select id from t1 where score=80);

6.结果集

将结果集作为一张表进行查询的时候,我们也需要用到别名。

**实例:** 从info表中的id和name字段的内容作为“内容”,输出id的部分
select a.id from (select id,name from info) a;
select 表.字段 ,字段 from 表;

二.MySQL视图

1.定义

数据库中的虚拟表,这张虚拟表中不包含真实数据,只是做了真实数据的映射
视图可以理解为镜花水月/倒影,动态保存结果集(数据)
基础表info (7行记录) ——》映射(投影)--视图

2.作用场景

作用范围:
select * from info;			#展示的部分是info表
select * from view_name;	#展示的一张或多张表

功能:
简化查询结果集、灵活查询、可以针对不同用户呈现不同结果集、相对有更高的安全性
本质而言视图是一种select(结果集的呈现)
PS:视图适合于多表连接浏览时使用!不适合增、删、改
而存储过程适合于使用较频繁的SQL语句,这样可以提高执行效率!

3.视图与表的区别与联系

(1)区别
①视图是已经编译好的sql语句。而表不是
②视图没有实际的物理记录。而表有。
show table status\G
③表只用物理空间而视图不占用物理空间,视图只是逻辑概念的存在,表可以及时对它进行修改,但视图只能有创建的语句来修改
④视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些SQL语句的集合。从安全的角度说,视图可以不给用户接触数据表,从而不知道表结构。
⑤表属于全局模式中的表,是实表;视图属于局部模式的表,是虚表。
⑥视图的建立和删除只影响视图本身,不影响对应的基本表。(但是更新视图数据,是会影响到基本表的)
(2)联系

视图(view)是在基本表之上建立的表,它的结构(即所定义的列)和内容(即所有数据行)都来自基本表,它依据基本表存在而存在。一个视图可以对应一个基本表,也可以对应多个基本表。视图是基本表的抽象和在逻辑意义上建立的新关系。

4.创建视图

#语法:
CREATE VIEW "视图表名" AS "SELECT 语句";

5.修改视图数据

update 视图名 set 修改数值 where 指定

6.更改源表数据

三.NULL值

在 SQL 语句使用过程中,经常会碰到 NULL 这几个字符。通常使用 NULL 来表示缺失 的值,也就是在表中该字段是没有值的。如果在创建表时,限制某些字段不为空,则可以使用 NOT NULL 关键字,不使用则默认可以为空。在向表内插入记录或者更新记录时,如果该字段没有 NOT NULL 并且没有值,这时候新记录的该字段将被保存为 NULL。需要注意 的是,NULL 值与数字 0 或者空白(spaces)的字段是不同的,值为 NULL 的字段是没有 值的。在 SQL 语句中,使用 IS NULL 可以判断表内的某个字段是不是 NULL 值,相反的用 IS NOT NULL 可以判断不是 NULL 值。

NULL值与空值区别:

空值长度为0,不占空间,NULL值的长度为null,占用空间
is null无法判断空值
空值使用"=“或者”<>"来处理(!=)
count()计算时,NULL会忽略,空值会加入计算

相关文章:

  • Golang案例开发之gopacket抓包三次握手四次分手(3)
  • C语言UNIX域套接字CS模型
  • 全局UI方法-弹窗六-自定义弹窗
  • Flask 与小程序 的图片数据交互 过程及探讨研究学习
  • 如何在群晖NAS搭建bitwarden密码管理软件并实现无公网IP远程访问
  • Install Docker
  • 【机器学习】代价函数
  • #Linux(make工具和makefile文件以及makefile语法)
  • spark: 从pulsar中读取数据
  • tcpdump 抓包
  • 基于STELLA系统动态模拟技术及在农业、生态及环境科学中的应用教程
  • WINDOWS设置代理链chain
  • 一文整合工厂模式、模板模式、策略模式
  • 什么是通配符SSL证书?
  • Webgl学习系列-认识Webgl
  • $translatePartialLoader加载失败及解决方式
  • 【MySQL经典案例分析】 Waiting for table metadata lock
  • Android 控件背景颜色处理
  • Asm.js的简单介绍
  • C++类中的特殊成员函数
  • C学习-枚举(九)
  • Django 博客开发教程 8 - 博客文章详情页
  • Docker入门(二) - Dockerfile
  • es6
  • Eureka 2.0 开源流产,真的对你影响很大吗?
  • Flannel解读
  • IDEA常用插件整理
  • Java,console输出实时的转向GUI textbox
  • Koa2 之文件上传下载
  • Linux快速复制或删除大量小文件
  • mysql innodb 索引使用指南
  • React-生命周期杂记
  • SegmentFault 技术周刊 Vol.27 - Git 学习宝典:程序员走江湖必备
  • 阿里云购买磁盘后挂载
  • 高度不固定时垂直居中
  • 如何邀请好友注册您的网站(模拟百度网盘)
  • 详解移动APP与web APP的区别
  • python最赚钱的4个方向,你最心动的是哪个?
  • 阿里云服务器购买完整流程
  • 蚂蚁金服CTO程立:真正的技术革命才刚刚开始
  • ​​​​​​​Installing ROS on the Raspberry Pi
  • ​你们这样子,耽误我的工作进度怎么办?
  • ​虚拟化系列介绍(十)
  • $.extend({},旧的,新的);合并对象,后面的覆盖前面的
  • (9)STL算法之逆转旋转
  • (Redis使用系列) SpringBoot 中对应2.0.x版本的Redis配置 一
  • (搬运以学习)flask 上下文的实现
  • (编程语言界的丐帮 C#).NET MD5 HASH 哈希 加密 与JAVA 互通
  • (二)Eureka服务搭建,服务注册,服务发现
  • (附源码)ssm教材管理系统 毕业设计 011229
  • (转)总结使用Unity 3D优化游戏运行性能的经验
  • .bat批处理(八):各种形式的变量%0、%i、%%i、var、%var%、!var!的含义和区别
  • .NET Core WebAPI中使用swagger版本控制,添加注释
  • .net/c# memcached 获取所有缓存键(keys)
  • .net6Api后台+uniapp导出Excel