MySql操作「数据查询」-20211222

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySql操作「数据查询」-20211222相关的知识,希望对你有一定的参考价值。

参考技术A

# 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 的查询 学习

MySQL-数据操作

阅读目录

一 介绍

MySQL数据操作: DML

========================================================

在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括

  1. 使用INSERT实现数据的插入
  2. UPDATE实现数据的更新
  3. 使用DELETE实现数据的删除
  4. 使用SELECT查询数据以及。

========================================================

本节内容包括:

插入数据
更新数据
删除数据
查询数据

 

二 插入数据INSERT

1. 插入完整数据(顺序插入)
    语法一:
    INSERT INTO 表名(字段1,字段2,字段3…字段n) VALUES(值1,值2,值3…值n);

    语法二:
    INSERT INTO 表名 VALUES (值1,值2,值3…值n);

2. 指定字段插入数据
    语法:
    INSERT INTO 表名(字段1,字段2,字段3…) VALUES (值1,值2,值3…);

3. 插入多条记录
    语法:
    INSERT INTO 表名 VALUES
        (值1,值2,值3…值n),
        (值1,值2,值3…值n),
        (值1,值2,值3…值n);
        
4. 插入查询结果
    语法:
    INSERT INTO 表名(字段1,字段2,字段3…字段n) 
                    SELECT (字段1,字段2,字段3…字段n) FROM 表2
                    WHERE …;

 

 

三 更新数据UPDATE

语法:
    UPDATE 表名 SET
        字段1=值1,
        字段2=值2,
        WHERE CONDITION;

示例:
    UPDATE mysql.user SET password=password(‘123’) 
        where user=’root’ and host=’localhost’;

 

四 删除数据DELETE、

语法:
    DELETE FROM 表名 
        WHERE CONITION;

示例:
    DELETE FROM mysql.user 
        WHERE password=’’;

练习:
    更新MySQL root用户密码为mysql123
    删除除从本地登录的root用户以外的所有用户

 

 

 

五 查询数据SELECT




以上是关于MySql操作「数据查询」-20211222的主要内容,如果未能解决你的问题,请参考以下文章

Mysql:数据操作_增删改查

MySQL 数据操作 DML(增删改查)

mysql简单操作,增删查改.

用python操作mysql数据库(之简单查操作)

Nodejs mysql 数据库增删改查 操作

node.js操作mysql数据库之增删改查