问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

怎么用IN,LIMIT,CONCAT,DISTINCT等MySQL关键字

发布网友 发布时间:2022-04-22 13:24

我来回答

1个回答

热心网友 时间:2023-06-22 11:39

# SELECT 数据查询


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

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

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

select 语法


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`子句中指定逗号分隔列的列表来查询表的部分数据


建议显式获取数据的列,原因如下:
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 关键字的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据给用户。**


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

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

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


## 指定别名 AS


### 1. 为表指定别名


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

2. 语法.

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

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

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

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


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

2. 语法:

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

- 含义:

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

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

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


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

ex2:


***
## *查询条数 LIMIT


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

- `指定初始位置`、

- `不指定初始位置`

- `OFFSET 组合`使用

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


### 指定初始位置


1. 语法

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

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

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

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

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


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

- `LIMIT 5`

- `SELECT * FROM tb_students_info LIMIT 15;`


### LIMIT 和 OFFSET 组合使用


1. 语法

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

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

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


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

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
我这个配置能玩大唐无双2吗 PK什么的能卡么? 求高手解答 这样的配置还要加什么玩大唐无双才不卡 这个配置能玩大唐无双双开吗? windows7旗舰版系统玩大唐无双零双开卡怎么办?卡死了。 玩大唐无双的时候双开过地图太卡怎么解决啊 全民枪战我用QQ号,但它说密码数字英文,下划线组成,应该怎样弄啊?_百 ... 小太阳取暖器头晕呕吐 取暖器用的会头晕吗,可能的原因和使用注意事项 男孩姓孙含越字好名字 简单特别的男孩名字越 中间是越的男孩名字大全 如何提高MySQL Limit查询的性能? MySQL语句如何更改,有关limit在in的中使用 有手机版iweb office吗? MYSQL中LIMIT用法是什么? 有没有一款手机软件像电脑软件office word那样?? 用手机怎么上word办公软件 可以在手机上使用的office有哪些软件 可编辑手机文件的word 软件 手机如何用word文档 手机上可以安装办公软件吗,怎么安装呀? 手机上可以使用office吗? 文档编辑软件 目前证监会批准的金融资产交易所有哪几家 什么是地方金融资产交易所 中原金融资产交易中心股份有限公司怎么样? 网状双眼皮贴的胶水怎么感觉不粘 双眼皮胶水怎么用图解 经常用双眼皮胶水,要怎么防止眼皮松弛?? 双眼皮胶水怎么用?有哪些危害? 双眼皮胶水干了。贴在眼皮上了。弄不下来。怎么办。 懂mysql的来帮忙下 关于limit语法 Mysql LIMIT语法错误 新手求解答 mysql中limit的问题 mysql limit分页时报错! mysql语句如果利用limit查询某一条之后的所有记录 mysql limit 查询问题 mysql中limit后面的参数能不能给变量 Mysql in(1,2,3) 1 数据的条数能限制吗? mysql 取指定数目的记录,按某字段 mysql 中 in的用法 期货开户云官方网站 期货开户云软件可靠吗 期货云开户需要什么资料? 华创期货互联网开户云 期货公司的网上开户流程有哪些? 手机开户交易期货如何开通啊 在哪个期货公司开户比较好,手续费保证金低? 期货开户条件? 什么是计算机网络,其目的是什么 微信转账可以直接转朋友微信吗?