MySQL高阶语句

增、删、改、查)

对 MySQL 数据库的查询,除了基本的查询外,有时候需要对查询的结果集进行处理。 例如只取 10 条数据、对查询结果进行排序或分组等等

1、按关键字排序

PS:类比于windows 任务管理器

使用 SELECT 语句可以将需要的数据从 MySQL 数据库中查询出来,如果对查询的结果进行排序,可以使用 ORDER BY 语句来对语句实现排序,并最终将排序后的结果返回给用户。这个语句的排序不光可以针对某一个字段,也可以针对多个字段

(1)语法

SELECT column1, column2, ... FROM table_name ORDER BY column1, column2, ...

ASC|DESC;

ASC 是按照升序进行排序的,是默认的排序方式,即 ASC 可以省略。SELECT 语句中如果没有指定具体的排序方式,则默认按 ASC方式进行排序。

DESC 是按降序方式进 行排列。当然 ORDER BY 前面也可以使用 WHERE 子句对查询结果进一步过滤。

2、对结果进行分组

通过 SQL 查询出来的结果,还可以对其进行分组,使用 GROUP BY 语句来实现 ,GROUP BY 通常都是结合聚合函数一起使用的,常用的聚合函数包括:计数(COUNT)、 求和(SUM)、求平均数(AVG)、最大值(MAX)、最小值(MIN),GROUP BY 分组的时候可以按一个或多个字段对结果进行分组处理。

(1)语法

SELECT column_name, aggregate_function(column_name)FROM table_name WHERE column_name operator value GROUP BY column_name;

按hobbid相同的分组,计算相同分数的学生个数(基于name个数进行计数)

限制结果条目

limit 限制输出的结果记录

在使用 MySQL SELECT 语句进行查询时,结果集返回的是所有匹配的记录(行)。有时候仅 需要返回第一行或者前几行,这时候就需要用到 LIMIT 子句

(1)语法

SELECT column1, column2, ... FROM table_name LIMIT [offset,] number

LIMIT 的第一个参数是位置偏移量(可选参数),是设置 MySQL 从哪一行开始显示。 如果不设定第一个参数,将会从表中的第一条记录开始显示。需要注意的是,第一条记录的 位置偏移量是 0,第二条是 1,以此类推。第二个参数是设置返回记录行的最大数目。

4、设置别名(alias ------》as)

在 MySQL 查询时,当表的名字比较长或者表内某些字段比较长时,为了方便书写或者 多次使用相同的表,可以给字段列或表设置别名。使用的时候直接使用别名,简洁明了,增强可读性

(1)语法

对于列的别名:SELECT column_name AS alias_name FROM table_name;

对于表的别名:SELECT column_name(s) FROM table_name AS alias_name;

在使用 AS 后,可以用 alias_name 代替 table_name,其中 AS 语句是可选的。AS 之后的别名,主要是为表内的列或者表提供临时的名称,在查询过程中使用,库内实际的表名 或字段名是不会被改变的

列别名设置示例:

select name as 姓名,score as 成绩 from info;

如果表的长度比较长,可以使用 AS 给表设置别名,在查询的过程中直接使用别名

临时设置info的别名为i

select i.name as 姓名,i.score as 成绩 from info as i;

此处AS起到的作用:

1、创建了一个新表t1 并定义表结构,插入表数据(与info表相同)

2、但是"约束"没有被完全"复制"过来 #但是如果原表设置了主键,那么附表的:default字段会默认设置一个0

相似:

克隆、复制表结构

create table t1 (select * from info);

#也可以加入where 语句判断

create table test1 as select * from info where score >=60;

在为表设置别名时,要保证别名不能与数据库中的其他表的名称冲突。

列的别名是在结果中有显示的,而表的别名在结果中没有显示,只在执行查询时使用。

开始

5、通配符

通配符主要用于替换字符串中的部分字符,通过部分字符的匹配将相关结果查询出来。

通常通配符都是跟 LIKE 一起使用的,并协同 WHERE 子句共同来完成查询任务。常用的通配符有两个,分别是:

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

_:下划线表示单个字符

6、子查询

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

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语句是为了,最后过滤出一个结果集,用于主语句的判断条件

视图:优化操作+安全方案

数据库中的虚拟表,这张虚拟表中不包含真实数据,只是做了真实数据的映射

视图可以理解为镜花水月/倒影,动态保存结果集(数据)

基础表info (7行记录) ------》映射(投影)--视图

作用场景[图]:

针对不同的人(权限身份),提供不同结果集的"表"(以表格的形式展示)

作用范围:

select * from info; #展示的部分是info表

select * from view_name; #展示的一张或多张表

区别:

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

②、视图没有实际的物理记录。而表有。

show table status\G

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

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

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

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

修改表不能修改以函数、复合函数方式计算出来的字段

查询方便、安全性

查询方便:索引速度快、同时可以多表查询更为迅速(视图不保存真实数据,视图本质类似select)

安全性:我们实现登陆的账户是root ------》所拥有权限 ,视图无法显示完整的约束

相关推荐
Bdygsl29 分钟前
MySQL(6)—— 视图
数据库·mysql
oradh30 分钟前
数据库入门概述
数据库·oracle·数据库基础·数据库入门
BullSmall38 分钟前
一套定制化高级 payload 合集
数据库·安全性测试
zbdx不知名菜鸡1 小时前
postgre sql 数据库查询优化
数据库·postgresql
9稳1 小时前
基于PLC的生产线自动升降机设计
开发语言·网络·数据库·嵌入式硬件·plc
四七伵1 小时前
Spring Boot项目中varchar字段为什么不用NULL?告别空指针从建表开始
数据库·后端
Mr.45672 小时前
JDK17+Druid+SpringBoot3+ShardingSphere5 多表分库分表完整实践(MySQL+PostgreSQL)
java·数据库·spring boot·mysql·postgresql
Elastic 中国社区官方博客2 小时前
使用 ES|QL 变量控件将仪表板转变为调查工具
大数据·运维·服务器·数据库·elasticsearch·搜索引擎·全文检索
feng68_2 小时前
Ansible还原数据库节点
linux·运维·数据库·ansible
乐hh2 小时前
清理MySQL数据
数据库·mysql