sql数据库开发是什么,sql数据库常用命令

sql数据库开发是什么,sql数据库常用命令

SQL 是一种非常常见但功能强大的工具,它可以帮助从任何数据库中提取、转换和加载数据。

数据查询的本质在于SQL。

随着公司和组织发现自己处理的数据量迅速增加,开发人员越来越需要有效地使用数据库来处理这些数据。

所以想要深入数据领域,SQL是必须的!

要掌握这门语言,你需要知道如何使用一些命令——其中大部分命令都基于一些基本命令。

对于整篇文章,我使用的是一个包含 5 个不同年龄和眼睛颜色的不同人的数据

1. select和from

SQL 中的SELECT命令是最简单的,但也是最重要的命令之一。每个查询都以开头,SELECT这就是你从数据库中获取数据的方式。

我们总是需要指出从哪里获取数据。而这正是FROM命令发挥作用的地方,它指示我们查询的表源是什么。

可以在 SQL 中执行的最简单的命令如下:

SELECT * FROM table

这相当于将“Hello World”打印到 java 或 python,现在你可能想知道那个星号是什么?它表示你希望从定义的表中选择所有列。星号是找出表中数据的好方法,但并不总是推荐用于生产代码。这就是为什么最好像下面这样指定要检索的每一列。

SELECT name, age, eyes_color FROM bbdd

运行结果将是:

sql数据库开发是什么,sql数据库常用命令

DISTINCT

DISTINCT用于查看列中的唯一值。该命令使用如下:

SELECT DISTINCT column_1 FROM table

例如,假设我们想看到所有可能的眼睛颜色。在这种情况下,我们将从表中包含的 eyes_colors 列中选择所有不同的值。

SELECT DISTINCT eyes_color FROM bbdd

运行结果将是:

sql数据库开发是什么,sql数据库常用命令

WHERE

每当你想根据特定条件过滤结果时,该WHERE命令就会出现。使用此 SQL 命令允许你将条件应用于SELECT语句。

SELECT * FROM table WHERE column_1 = "Given Condition"

假设我们只想知道蓝眼睛的人的名字。所需的查询将是:

SELECT DISTINCT * FROM bbdd WHERE eyes_color = "Blue"

此查询现在仅限于蓝眼睛的人。对应的输出是:

sql数据库开发是什么,sql数据库常用命令

我们可以将多个条件与两个AND或OR运算符结合起来。

  • AND它的工作方式与在英语中完全一样:它将另一个条件应用到语句中。

select * FROM bbdd WHERE eyes_color = "Blue" AND age < 20

相应的输出包含所有蓝眼睛且小于 20 岁的人。

sql数据库开发是什么,sql数据库常用命令

  • OR用作多条件测试仪。这意味着将保留满足任何条件的任何行。

SELECT * FROM bbdd WHERE eyes_color = "Blue" OR eyes_color = "Green"

在这种情况下,相应的输出包含所有蓝眼睛或绿眼睛的人。

sql数据库开发是什么,sql数据库常用命令

ORDER BY

ORDER BY命令用于按特定顺序对结果进行排序。你需要指定列和顺序,可以是ASC升序也可以是DESC降序。

SELECT * FROM table ORDER BY column1 ASC/DESC

如果ASC or DESC未定义,则排序顺序默认为升序。

SELECT * FROM bbdd ORDER BY age DESC

在这种情况下,我们的输出将从老年人到年轻人排序。

sql数据库开发是什么,sql数据库常用命令

你也可以按多列排序。

SELECT * FROM bbdd ORDER BY eyes_color, age DESC

在第二种情况下,我们获得了按 eye_colors 和 age 排序的表。顺序层次结构将遵循 ORDER BY 命令后每一列出现的顺序。

sql数据库开发是什么,sql数据库常用命令

聚合函数

聚合函数对一系列值执行计算并返回单个值。聚合函数的一些例子是:

  • COUNT()返回总行数。通常与DISTINCT命令一起使用以计算唯一元素。
  • SUM()返回所有值的总和
  • MAX()返回最大值
  • MIN()返回最小值
  • AVG()返回平均值

假设我们想知道数据集中的人数。在这种情况下,我们只是计算所有人,而不使用任何 group by 命令。

SELECT COUNT(*) FROM bbdd

sql数据库开发是什么,sql数据库常用命令

现在假设我们想知道所有可能的眼睛颜色。在这种情况下,我们重复前面的查询,只计算 eyes_color 列并使用DISTINCT命令。

SELECT COUNT(DISTINCT eyes_color) as "眼睛颜色的种类" FROM bbdd

相应的输出将是:

sql数据库开发是什么,sql数据库常用命令

GROUP BY

GROUP BY将按相同的值对数据进行分组。它经常与聚合函数一起使用来汇总特定列或列组的属性。

现在让我们想象一下,我们想知道每种不同眼睛颜色的人有多少。我们可以重复前面的逻辑查询,但将结果按 eyes_color 列分组。

SELECT eyes_color, COUNT(*) FROM bbdd GROUP BY eyes_color

正如我们可以检查的那样,相应的输出包含我们所期望的。

sql数据库开发是什么,sql数据库常用命令

UNION

UNION是一个很棒的命令,因为它允许你将行附加到彼此。与附加匹配列的连接不同,UNION可以附加不相关的行,前提是它们具有相同的列数和名称。

你可以将UNION 其视为组合两个查询结果的一种方式。联合只会返回两个查询之间存在唯一行的结果。

SELECT * FROM bbdd WHERE eyes_color = "Blue" UNION SELECT * FROM bbdd WHERE eyes_color = "Brown" UNION SELECT * FROM bbdd WHERE eyes_color = "Green"

sql数据库开发是什么,sql数据库常用命令

AS

AS 命令用于在查询过程中重命名特定的列或特定的表。它是存在于你正在运行的查询中的昵称。

  • 重命名列

就像选择列并在命令后写下所需的新名称一样简单AS。

SELECT column_1 AS new_name FROM bbdd

  • 重命名表

该命令AS用于在表声明后立即为其分配别名。

SELECT A.age FROM bbdd as A

你可以使用任何你喜欢的有效名称,但我强烈建议使用字母表中的字母。在每个列名称之前,别名都带有前缀。你可以键入一个简单易记的字母,而不是键入一个长表名。

CASE WHEN、ELSE和THEN

如果你以前使用过任何其他编程语言,这与 if-else 语句非常相似。

实际上,用简单的英语来说,该命令听起来有点像这样:

  1. CASE WHEN— 如果满足条件。
  2. THEN- 做这个。
  3. ELSE- 否则做这件事。

让我们看一个例子来巩固这个想法。假设我们要创建一个新列,告诉我们这个人是青少年、年轻人还是成年人。CASE WHEN我们可以使用命令从头开始轻松创建此分段。

SELECT *, CASE WHEN age < 20 THEN 'teen' WHEN age >= 20 AND age < 30 THEN 'yongster' ELSE "adult" END AS type FROM bbdd

如你所见,前面的查询创建了三个不同的条件:

  1. 如果年龄小于 20 岁,则为 Teen。
  2. 如果年龄在 20 到 30 之间,则为 Youngster。
  3. 在任何其他情况下,它都是一个成年人。

相应的输出包含每个人及其相应的类型标签。

sql数据库开发是什么,sql数据库常用命令

JOIN

JOIN命令是管理数据的关键命令。它允许我们从不同的源和表中获取数据并将它们合并在一起。三种最常见的连接是:

  • INNER JOIN— 语句仅返回那些具有匹配值的记录或行,并用于检索出现在两个表中的数据。

sql数据库开发是什么,sql数据库常用命令

  • LEFT JOIN— 按照左表的结构给出两个表之间匹配行的输出。如果左表中没有记录匹配,它会显示那些具有空值的记录。

sql数据库开发是什么,sql数据库常用命令

  • CROSS JOIN— 返回每个表中行的所有组合。请注意,此连接不需要任何条件来连接两个表。

sql数据库开发是什么,sql数据库常用命令

让我们想象一下,现在我们有一个包含每个人的性别的附加表。因此,使用左连接,我们可以将两个表合并为一个由公共列连接的表,在本例中,按名称连接。

SELECT T1.name, T1.age, T1.eyes_color, T2.gender FROM bbdd AS T1 LEFT JOIN bbdd_gender AS T2 ON T1.name = T2.name

相应的输出包含合并到单个表中的所有信息。

sql数据库开发是什么,sql数据库常用命令

希望这篇文章对你理解 SQL 的基础知识很有帮助,并随时向我提出任何进一步的问题。

如果你发现我的任何文章对你有帮助或者有用,麻烦点赞、转发或者赞赏。 谢谢!

本文【sql数据库开发是什么,sql数据库常用命令】由作者: Web服务 提供,本站不拥有所有权,只提供储存服务,如有侵权,联系删除!
本文链接:https://www.cuoshuo.com/blog/4527.html

(0)
上一篇 2023-03-15 08:21:12
下一篇 2023-03-15 08:34:53

相关推荐

  • ubuntu输入法怎么切换中文

    引言 在Ubuntu系统中,无论是写文档还是在程序中写注释,都经常需要用到中文输入法。本文简单介绍了三种输入法框架,然后详细介绍了在Ubuntu 20.04系统中,IBus框架和Fcitx框架支持的中文输入法的配置和安装。 一、添加中文语言支持 在安装中文输入法之前,首先要添加中文语言支持。 1、单击Ubuntu桌面右上角的三角符号,然后选择“Setting…

    2023-03-21
    000
  • 电脑磁盘如何重新分盘

    电脑硬盘重新分区是指为了合理利用存储空间容量,更高效地管理磁盘空间并提升电脑的整体效能,重新划分硬盘分区,使之符合新的存储需求。那么,电脑怎么重新分区硬盘呢?在这里,易我小编将介绍三种好用的磁盘重新分区方法。 一、Diskpart对硬盘重新分区 Diskpart是一种命令提示符,根据提示进行命令输入。在Windows环境下,命令行程序为cmd.exe,是一个…

    2023-03-20
    000
  • mysql安装教程图解最新

    mysql作为日常开发中常用到的数据库,对每个程序员来说至关重要,今天就跟着我来进行一次mysql的安装之旅吧。 一、安装 1、安装包的方式 1.1、获取安装包 对mysql有过接触的人来说,都知道mysql分为商业版和社区版,由于这里仅仅作为开发、学习之用,这里选择社区版进行安装。首先打开官方网站。 https://www.mysql.com/ 进入到下载…

    2023-03-10
    600
  • dropdownlist怎么清空

    下拉列表,又称下拉框,是一个可切换列表,其中包含多个选项,一次只能选择一个选项。 当你需要从多个答案中选中某一个时,可以采用此部件。比如国家的选择/地区的选择等。 添加,删除和重新排序Droplist选项 9DropList.png 元件添加:直接从左侧元件库上拖入; 下拉列表的编辑:直接双击Droplist; 选项的添加:点击左侧上方添加按钮(上图中第一个…

    2023-03-20
    000
  • 二分法查找是什么意思

    引入: 二分法思想无处不在,我们经常玩的猜数字游戏,0-99的范围,最多需要多少次我就可以猜对呢? 使用二分法思想,最多仅仅需要7次就可以查找到。 二分法查找是非常恐怖的,以2的倍数缩小范围。所以时间复杂度O(logn) 局限性: 1.针对二分法查找的数据必须是有序的。 2.二分法查找依赖于顺序表结构,也就是数组。因为二分法需要随机访问元素,也就是O(1)的…

    2023-03-12
    400
  • 快速启动显示桌面图标不见了

    XP系统任务栏上的显示桌面图标不见了怎么办?XP系统任务栏上有一个显示桌面的图标,能够让我们快速切回到系统桌面,但是有用户反映这个图标不见了,如何解决?请看下文介绍。 解决方法: 1.右击桌面左下角的开始菜单,选择“属性”,如下图所示。 2.切换到“任务栏”选项卡,勾选“显示快速启动”,点击“确定”按钮,如下图所示。 3.可以发现显示桌面图标又回到任务栏中了…

    2023-03-17
    100
  • html表单get和post的区别_html表单提交按钮

    我们在Web表单提交,常常需要选择提交方法,这时我们会用到GET和POST方法。但关于它们之间的区别你又知道多少。今天我们就来了解它们 这两方法其实是HTTP协议中的请求方法(关于HTTP协议可以阅读之前我写的《解密Web通信协议——超文本传输协议》)我们先通过一个例子来看看它们之间的区别。 通过下面源代码来查看: 我们来看一下地址栏无输入时为: file:…

    2023-03-11
    500
  • vector嵌套vector用法 vector中函数用法

    一:介绍 vector是C++标准模板库,是一个容器,底层是数组,为连续内存。 命名空间为std,所属头文件为<vector> 注意:不是<vector.h> vector存储数据时,会分配一个存储空间,如果继续存储,该分配的空间已满,就会分配一块更大的内存,把原来的数据复制过来,继续存储,这些性能也会一定程度上会有损耗 二:常用操作…

    2023-03-15
    100
  • 冒泡排序算法c语言代码_输入n个数进行冒泡排序C语言

    C语言是过去几十年软件和硬件两个阵营之间,签署的最坚实的契约。硬件为C语言的语义提供了最能发挥其性能的基础构件,而软件虽然搞了很多的圆环套圆环般的层次,但最终都以C语言作为最后的沉淀收尾。—-后面也会有C版的迷你程序!!! 之所以起头写这样系列的文档,主要是锻炼自己的编码能力,类似于leetcode吧。 浅话到此,C版的迷你程序、Python版的…

    2023-03-09
    500
  • css链接样式为什么用id_css链接样式怎么设置

    首先让我们回顾下前端入门——html 超链接的用法 <a href="url"> , 超链接是一个非常伟大的发明,它链接了整个互联网,没有它就没有互联网。 超链接在发明之初就给它设计了一个默认的样式,就是蓝色带下划线的样式,如下图: 关于为什么超链接是蓝色带下划线的历史,可以参考这里:https://baijiahao.bai…

    2023-03-08
    800

发表回复

登录后才能评论
返回顶部
错说博客上线啦!