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

Mysql高价语句

一.高级语法的查询语句

1.排序语法(默认的排序方式就是升序)。

升序ASC:select * from test01 order by name;

降序DESC:select * from test01 order by name desc;

多个列排序:以多个列作为排序,只有第一个参数有相同的值,第二个字段才有意义。

 2.where条件的筛选功能(比较符号),也就是区间判断,and、or。

 

嵌套多条件

3.分组查询:对sql查询的结果进行分组,使用group by 语句来实现,group by配合聚合函数一起用,二者必须一起使用。

在聚合函数分组语句中,所有的非聚合函数列都要在group by语句当中。

聚合函数的类型:统计:count     求平均数:avg      最大值:MAX      最小值:min     求和:sum

统计

 统计筛选(where和having):where要在group by语句前

having要在group by后

练习:

 4.limit 1,3     1是位置偏移量(可选参数),如果不设定位置偏移量,默认就从第一行开始,默认值的值是0。

 5.表和列的别名:因为在实际工作中,表的名字和列的名字可能会很长,书写起来不太方便,多次声明表和列时完整的展示太复杂,设置别名可以使书写简化,可读性增加,简洁明了。

以下两个语法是一样的as可以不加

 

 6.as对表进行复制:只能复制内容,约束条件复制不了

 只复制规定范围的内容

 7.通配符:like模糊查询。

%匹配0个、1个或者多个字符,

匹配包含s都算

 

_下划线:匹配单个字符 。

 下划线及%联合使用

8.子查询:内查询,嵌套查询,selsect语句当中有嵌套了一个select,嵌套的select才是子查询,查询的时候是先执行子查询语句,外部的select再根据子条件的结果进行过滤查找;子查询可以是多个表,也可以是同一张表;关联语句in  , not  in。

同一张表

 

 多个表

 根据test表中id的行来改变info表里的scroce的值。

9.exists:判断子查询的结果是否为空,不为空返回true,空返回false 

 

 10.子查询当中的多表查询和别名:

查出info表成绩大于80的数据 

 info表和test表,这两张的id部分相同,然后根据id相同的部分,查询info表的平均值

 二、mysql的视图

1.视图时一个虚拟的表,表的数据基于查询的结果生成;视图可以简化复杂的查询,隐藏复杂的细节,访问数据更安全;是多表数据的集合体。

2.视图与表的区别:

   存储方式:表是实际的数据表,视图不存储数据,仅仅是查询结果的虚拟表

   数据更新:更新表可以直接更新视图表的数据

   占用空间:表占用空间,视图表不占用空间,只是一个动态结果的展示

   视图表的数据可能是一张表的部分查询数据,也可能是多个表的一部分查询数据

3.查询当前数据库当中的是视图表:

show full tables in xy102 where table_type like 'view';

创建视图表:

create view test as select * from info where score >= 80;

4.创建视图表内容只有info表score大于等于80的数据

5.单独修改视图或者表的内容时,二者的值都会发生改变

6.​​​​​​​

 

7.删除视图表

 

三、连接查询:把两张表或者多个表的记录结合起来,基于这些表共同的字段进行拼接,首选要确定一个主表作为结果集,然后把其它表的行有选择性的选定到主表的结果上。 

1.内连接:两张表或者多张表之间符合条件的数据记录的集合   inner  join 

 

 2.左连接:左表连接,left jion,   left outer join  写在left左边的为左表

左连接以左表为基础,接收左表的所有行,以左表的记录和右表的记录进行匹配,匹配左表的所有,以及右表中符合条件的行,不符合的显示null。已比较条件为标准,展示结果。两个表相同的部分展示出来,做拼接。不同的结果显示null。

3. 右连接:在right右边的为主表

右连接:右外连接,right iion right outer join右连接以右表为基础,接收右表的所用行,以右表记录和左表的记录进行匹配。匹配右表的所有,以及左表中符合条件的行,不符合显示null

http://www.lryc.cn/news/404587.html

相关文章:

  • ArcGIS Pro SDK (九)几何 6 包络
  • 单链表<数据结构 C版>
  • 监控电脑进程,避免程序在打开前就已经在运行
  • 【MySQL进阶篇】存储对象:视图、存储过程及触发器
  • 算法day05 master公式估算递归时间复杂度 归并排序 小和问题 堆排序
  • 基于jeecgboot-vue3的Flowable流程仿钉钉流程设计器-支持VForm3表单的选择与支持
  • 【刷题汇总 -- 压缩字符串(一)、chika和蜜柑、 01背包】
  • 《Exploring Aligned Complementary Image Pair for Blind Motion Deblurring》
  • vue2学习笔记9 - 通过观察vue实例中的data,理解Vue中的数据代理
  • 04 Git与远程仓库
  • 数据库之表的查询
  • String 和StringBuilder字符串操作快慢的举例比较
  • Java代码基础算法练习-竞猜卡片值-2024.07.22
  • Python爬虫-淘宝搜索热词数据
  • Leetcode二分搜索法浅析
  • 昇思25天学习打卡营第24天|ResNet50迁移学习
  • Shell 构建flutter + Navtive 生成IPA
  • python gradio 的输出展示组件
  • SwiftUI 6.0(Xcode 16)新 PreviewModifier 协议让预览调试如虎添翼
  • STM32被拔网线 LWIP的TCP无法重连解决方案
  • Linux下开放指定端口
  • 亚马逊测评行为的识别与防范:教你如何搭建安全的测评环境
  • 如何通过成熟的外发平台,实现文档安全外发管理?
  • SCI一区级 | Matlab实现SSA-CNN-GRU-Multihead-Attention多变量时间序列预测
  • Mysql中的几种常见日志
  • 2024年7月22日(nfs samba)
  • 黑龙江网络安全等级保护测评策略概述
  • 笔记 7 :linux 011 注释,函 bread () , get_hash_table () , find_buffer ()
  • vscode配置latex环境制作【文档、简历、resume】
  • 如何学习Spark:糙快猛的大数据之旅