百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySql操作「数据查询」-20211222

wptr33 2024-11-17 16:44 23 浏览

# SELECT 数据查询


## 基础
显示如何使用简单的`select`语句查询单个表中的数据 使用`SELECT`语句从表或视图获取数据。

表由行和列组成,如电子表格。 通常,我们只希望看到子集行,列的子集或两者的组合。

SELECT语句的结果称为结果集,它是行列表,每行由相同数量的列组成。

select 语法


SELECT 
	column_1, column_2, ... 
 FROM 
	table_1 [INNER | LEFT |RIGHT] 
JOIN 
	table_2 
ON 
	conditions 
 WHERE 
 	conditions 
 GROUP 
 	BY column_1 
 HAVING 
 	group_conditions 
 ORDER 
 	BY column_1 
 LIMIT offset, length;


SELECT语句由以下列表中所述的几个子句组成:
1. SELECT 之后是逗号分隔列或星号(*)的列表,表示要返回所有列。

2. FROM 指定要查询数据的表或视图。

3. JOIN 根据某些连接条件从其他表中获取数据。

4. WHER E过滤结果集中的行。

5. GROUP BY将一组行组合成小分组,并对每个小分组应用聚合函数。

6. HAVING 过滤器基于GROUP BY子句定义的小分组。

7. ORDER BY 指定用于排序的列的列表。

8. LIMIT 限制返回行的数量。


语句中的`SELECT`和`FROM`语句是必须的,其他部分是可选的。

`SELECT`语句允许通过在`SELECT`子句中指定逗号分隔列的列表来查询表的部分数据

SELECT lastname, firstname, jobtitle FROM employees; 
#选出lasrname,firstname,jobtitle三列 SELECT * FROM employees; 选出所有列数据。


建议显式获取数据的列,原因如下:
1. 使用星号(*)可能会返回不使用的列的数据。 它在MySQL数据库服务器和应用程序之间产生不必要的I/O磁盘和网络流量。

2. 如果明确指定列,则结果集更可预测并且更易于管理。 想象一下,当您使用星号(*)并且有人通过添加更多列来更改表格数据时,将会得到一个与预期不同的结果集。

3. 使用星号(*)可能会将敏感信息暴露给未经授权的用户

格式 `select 列筛选 form table where 行筛选`
还有一些有用的运算符可以在WHERE子句中使用来形成复杂的条件,例如:


>BETWEEN 选择在给定范围之内的值。

>LIKE 匹配基于模式匹配的值。

>IN 指定值是否匹配列表中的任何值。

>IS NULL 检查该值是否为NULL。


## SELECT 子查询


在一个查询过程中 嵌套另一个查询,子查询的结果作为外部查询的条件或者数据范围来使用。


分为 3 类:


1. where 型

- `select展示列名 from 表名 where 列名 运算符[in...] (select 对应列名 from ...)`

- 这个列名 和 对应列名 应该做到类型相同

- 如果不加入运算符 也可使用IN 这些类似的符号 - `select 展示列名 from 表名 where 列名 in (select 对应列名 from ...)`

- ex:

`select 展示列名 from 表名 where 列名 >ALL(select 对应列名 from ....)`;

比子查询的值都大

`select 展示列名 from 表名 where 列名 >ANY(select 对应列名 from ....);`

比子查询的任意一个值大


2. from 型

- `select 展示列名 from 表名 inner join (select 列名 from ...) 临时表名 on 条件;`

- 其中,select的子查询所得的表 为临时表,后跟临时表名,可在条件判断中指代

3. exist 型

- `select 展示列 from 表名 where exists (select 列名 from 表名 where 条件);`

- 将主查询的结果带入子查询进行条件判断和匹配,如果查询出结果即保留。


## 去重 DISTINCT


SELECT 语句执行简单的数据查询时,返回的是所有匹配的记录。`distinct` 实现查询不重复的数据


**DISTINCT 关键字的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据给用户。**

 
SELECT DISTINCT <字段名> FROM <表名>;
# 字段名”为需要消除重复记录的字段名称,多个字段时用逗号隔开。


使用 `DISTINCT` 关键字时需要注意以下几点:
- `DISTINCT` 关键字只能在 `SELECT` 语句中使用。

- 在对一个或多个字段去重时,`DISTINCT` 关键字必须在所有字段的最前面。

- 如果 `DISTINCT` 关键字后有多个字段,则会对多个字段进行组合去重,也就是说,只有多个字段组合起来完全是一样的情况下才会被去重。


## 指定别名 AS


### 1. 为表指定别名


1. 当表名很长的时候 或者 执行了一些特殊的查询的时候,为方便操作,可以为表指定一个别名,用以替代原来的名称

2. 语法.

3. `<表名> as <别名>` - 含义: - `<表名>` : 数据库中存储的数据表名称。

- `<别名>` : 查询的时候指定的新的名称。

- `as` : 此关键字 可以 省略,省略之后要将 `表名`与`别名`用 `空格` 分开

***注意:表的别名不能与该数据库的其它表同名。字段的别名不能与该表的其它字段同名。在条件表达式中不能使用字段的别名,否则会出现“ERROR 1054 (42S22): Unknown column”这样的错误提示信息。***
***ex1:


SELECT stu.name,stu.height FROM tb_students_info AS stu;
SELECT stu.name,stu.height FROM tb_students_info stu;


***
### 2. 为字段指定别名
1. 在使用 SELECT 语句查询数据时,MySQL 会显示每个 SELECT 后面指定输出的字段。有时为了显示结果更加直观,我们可以为字段指定一个别名。

2. 语法:

3. `<字段名> [AS] <别名>`

- 含义:

- `<字段名>`:为数据表中字段定义的名称。

- `<字段别名>`:字段新的名称。

- `AS` 关键字可以省略,省略后需要将字段名和别名用空格隔开


***注意:表别名只在执行查询时使用,并不在返回结果中显示。而字段定义别名之后,会返回给客户端显示,显示的字段为字段的别名******

ex2:


SELECT name AS student_name, age AS student_age FROM tb_students_info;
SELECT name AS student_name, age student_age FROM tb_students_info;


***
## 限制查询条数 LIMIT


1. LIMIT 关键字有 3 种使用方式,即

- `指定初始位置`、

- `不指定初始位置`

- `OFFSET 组合`使用

(。。。。。 我之前一直不知道, 只会使用 `limit 200`。。。。。)


### 指定初始位置


1. 语法

- `LIMIT 初始位置,记录数`

- 初始位置”表示从哪条记录开始显示;第一条记录的位置是 0,第二条记录的位置是 1。后面的记录依次类推。

- “记录数”表示显示记录的条数。

- *LIMIT 后的两个参数必须都是正整数。

* ex:tb_students_info 表中,使用 LIMIT 子句返回从第 4 条记录开始的行数为 5 的记录,SQL 语句和运行结果如下。


mysql> SELECT * FROM tb_students_info LIMIT 3,5; 
LIMIT之后的 3 是从第四行开始 5 是返回的行数


### 不指定初始位置
记录从第一条记录开始显示。显示记录的条数由 LIMIT 关键字指定。
1. 语法

- `LIMIT 5`

- `SELECT * FROM tb_students_info LIMIT 15;`


### LIMIT 和 OFFSET 组合使用


1. 语法

- `LIMIT 记录数 OFFSET 初始位置`

- 参数和 LIMIT 语法中参数含义相同,“初始位置”指定从哪条记录开始显示;“记录数”表示显示记录的条数。


SELECT * FROM tb_students_info LIMIT 5 OFFSET 3;



该语句返回的是从第 4 条记录开始的之后的 5 条记录。即“LIMIT 5 OFFSET 3”意思是获取从第 4 条记录开始的后面的 5 条记录,和“LIMIT 35”返回的结果相同。


***2021-12-22 今天先学到这里 明天继续 MySql 的查询 学习

相关推荐

Linux高性能服务器设计

C10K和C10M计算机领域的很多技术都是需求推动的,上世纪90年代,由于互联网的飞速发展,网络服务器无法支撑快速增长的用户规模。1999年,DanKegel提出了著名的C10问题:一台服务器上同时...

独立游戏开发者常犯的十大错误

...

学C了一头雾水该咋办?

学C了一头雾水该怎么办?最简单的方法就是你再学一遍呗。俗话说熟能生巧,铁杵也能磨成针。但是一味的为学而学,这个好像没什么卵用。为什么学了还是一头雾水,重点就在这,找出为什么会这个样子?1、概念理解不深...

C++基础语法梳理:inline 内联函数!虚函数可以是内联函数吗?

上节我们分析了C++基础语法的const,static以及this指针,那么这节内容我们来看一下inline内联函数吧!inline内联函数...

C语言实战小游戏:井字棋(三子棋)大战!文内含有源码

井字棋是黑白棋的一种。井字棋是一种民间传统游戏,又叫九宫棋、圈圈叉叉、一条龙、三子旗等。将正方形对角线连起来,相对两边依次摆上三个双方棋子,只要将自己的三个棋子走成一条线,对方就算输了。但是,有很多时...

C++语言到底是不是C语言的超集之一

C与C++两个关系亲密的编程语言,它们本质上是两中语言,只是C++语言设计时要求尽可能的兼容C语言特性,因此C语言中99%以上的功能都可以使用C++完成。本文探讨那些存在于C语言中的特性,但是在C++...

在C++中,如何避免出现Bug?

C++中的主要问题之一是存在大量行为未定义或对程序员来说意外的构造。我们在使用静态分析器检查各种项目时经常会遇到这些问题。但正如我们所知,最佳做法是在编译阶段尽早检测错误。让我们来看看现代C++中的一...

ESL-通过事件控制FreeSWITCH

通过事件提供的最底层控制机制,允许我们有效地利用工具箱,适时选择使用其中的单个工具。FreeSWITCH是一个核心交换与混合矩阵,它周围有几十个模块提供各种功能特性。我们完全控制了所有的即时信息,这些...

物理老师教你学C++语言(中篇)

一、条件语句与实验判断...

C语言入门指南

当然!以下是关于C语言入门编程的基础介绍和入门建议,希望能帮你顺利起步:C语言入门指南...

C++选择结构,让程序自动进行决策

什么是选择结构?正常的程序都是从上至下顺序执行,这就是顺序结构...

C++特性使用建议

1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...

C++程序员学习Zig指南(中篇)

1.复合数据类型结构体与方法的对比C++类:...

研一自学C++啃得动吗?

研一自学C++啃得动吗?在开始前我有一些资料,是我根据网友给的问题精心整理了一份「C++的资料从专业入门到高级教程」,点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!!个人...

C++关键字介绍

下表列出了C++中的常用关键字,这些关键字不能作为变量名或其他标识符名称。1、autoC++11的auto用于表示变量的自动类型推断。即在声明变量的时候,根据变量初始值的类型自动为此变量选择匹配的...