【MySQL】(基础篇四) —— 检索数据

检索数据

检索数据是我们使用数据库时进行最多的操作,其中包括了检索条件、排序、过滤、分组等等。我会在后续的多篇博客中为你进行详细地介绍它们。

这次先让我们来粗略的了解一下SELECT,为了使用SELECT检索表数据,必须至少明确两点信息——想选择什么,以及从什么地方选择。

为了方便后面的学习,我准备了一些数据库以及数据表信息,网盘链接:https://pan.baidu.com/s/1A2je66sLrpd7rbzuSK2LPQ?pwd=1023 提取码:1023

或者直接运行SQL命令,我希望你可以和我一起进行实操,让自己掌握mysql更加熟练,具体的SQL命令传送门:https://blog.csdn.net/dao_cao_renshuai/article/details/139565004

检索单个列

我们将从简单的SQL SELECT语句开始介绍,此语句如下所示:

【示例】在employees表中查找last_name字段

SELECT last_name
FROM employees;

运行结果查出表中所有last_name字段的信息

在这里插入图片描述

上述语句利用SELECT 语句从employees表中检索一个名为last_name的列。所需的列名在SELECT关键字之后给出,FROM关键字指出从其中检索数据的表名。如果你的输出结果顺序和我不同也没有关系,这涉及到sql的排序问题,我会在后面的内容中为你详细讲解。

多条SQL语句必须以分号( ; )分隔。MySQL如同多数DBMS一样,不需要在单条SQL语句后加分号。但特
定的DBMS可能必须在单条SQL语句后加上分号。当然,如果愿意可以总是加上分号。事实上,即使不一定需要,但加上分号肯定没有坏处。如果你使用的是mysql命令行,则必须加上分号来结束SQL语句。

在处理SQL语句时,其中所有空格(空格、制表符、换行)都被忽略。SQL语句可以在一行上给出,也可以分成许多行。多数SQL开发人员认为将SQL语句分成多行更容易阅读和调试。

检索多个列

要想从一个表中检索多个列,使用上述相同的SELECT语句。唯一的不同是必须在SELECT关键字后给出多个列名,列名之间必须以逗号分隔。

【示例】在employees表中查找last_name字段和first_name字段

SELECT last_name, first_name
FROM employees;

运行结果:

在这里插入图片描述

检索所有列

除了指定所需的列外(如上所述,一个或多个列),SELECT语句还可以检索所有的列而不必逐个列出它们。这可以通过在实际列名的位置使用星号(*)通配符来达到,如下所示:

【示例】查询employees表中的所有字段

SELECT *
FROM employees;

运行结果:

在这里插入图片描述

一般,除非你确实需要表中的每个列,否则最好别使用星号(*)通配符。虽然使用通配符可能会使你自己省事,不用明确列出所需列,但检索不需要的列通常会降低检索和应用程序的性能。

DISTINCT去重

SELECT返回所有匹配字段的行。但是,如果你不想要每个值每次都出现,怎么办?假如你想得出employees表中产品的所有工种job_id:

在这里插入图片描述

解决办法是使用DISTINCT关键字,顾名思义,此关键字指示MySQL只返回不同的值。

【示例】去重查询employees表中产品的所有job_id:

SELECT DISTINCT job_id
FROM employees;

运行结果:

在这里插入图片描述

DISTINCT关键字应用于所有列而不仅是前置它的列。如果给出SELECT DISTINCT vend_id,prod_price,除非指定的两个列的结果都不同,否则所有行都将被检索出来。

LIMIT限制结果条数

SELECT语句返回所有匹配的行,它们可能是指定表中的每个行。为了返回第一行或前几行,可使用LIMIT子句。

【示例】去重查询employees表中产品的所有job_id,且限制只查看前五个结果:

SELECT DISTINCT job_id
FROM employees
LIMIT 5;

运行结果:

在这里插入图片描述

【示例】去重查询employees表中产品的所有job_id,限制从第五个数据开始只查看五个结果:

SELECT DISTINCT job_id
FROM employees
LIMIT 5,5;

运行结果:

在这里插入图片描述

LIMIT 5, 5指示MySQL返回从行5开始的5行。第一个数为开始位置,第二个数为要检索的行数。

检索出来的第一行为行0而不是行1。因此,LIMIT 1, 1将检索出第二行而不是第一行。

LIMIT中指定要检索的行数为检索的最大行数。如果没有足够的行(例如,给出LIMIT 10, 5,但只有13行),MySQL将只返回它能返回的那么多行。

完全限定表名

迄今为止使用的SQL例子只通过列名引用列。也可能会使用完全限定的名字来引用列(同时使用表名和列字)。请看以下例子:

【示例】使用完全限定的列名(列名前面加上表名)来查询employees表中的last_name字段

SELECT employees.last_name
FROM employees;

这样做运行的结果和我们检索单个列中例子查询效果一样

【示例】使用完全限定的表名(表名前面加上数据库名)完成查询employees表中的last_name字段

SELECT last_name
FROM myemployees.employees;

这条语句在功能上也等于刚使用的那条语句,在有一些情形下需要完全限定名。现在,你只需要了解一下这个语法,遇到需要使用它的时候,我会为你详细解释。

相关推荐

  1. MySQL数据库基础二)

    2024-06-13 04:26:01       16 阅读
  2. MySQL数据库基础-SQL

    2024-06-13 04:26:01       17 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-13 04:26:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-13 04:26:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-13 04:26:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-13 04:26:01       20 阅读

热门阅读

  1. 中介子方程十三

    2024-06-13 04:26:01       9 阅读
  2. AI大汇总

    2024-06-13 04:26:01       14 阅读
  3. HLS入门

    HLS入门

    2024-06-13 04:26:01      10 阅读
  4. C++Primer Plus6编程题(第四章)

    2024-06-13 04:26:01       11 阅读
  5. Web前端如何华丽转身成为网页制作高手

    2024-06-13 04:26:01       12 阅读
  6. 英智AI算力平台上成功运行腾讯TI-ONE训练平台

    2024-06-13 04:26:01       10 阅读
  7. 搜索与图论:所有可达路径(DFS算法)

    2024-06-13 04:26:01       8 阅读
  8. 鸿蒙HarmonyOS $r(““)与$rawfile(““)的区别

    2024-06-13 04:26:01       7 阅读