上犹电脑信息网我们一直在努力
您的位置:上犹电脑信息网 > 文件问题 > 利用 SQL 进行数据分析初学者教程-ep1-DAT文件

利用 SQL 进行数据分析初学者教程-ep1-DAT文件

作者:上犹日期:

返回目录:文件问题

利用 SQL 进行数据分析初学者教程-ep1由 Tomi Mester 写于2017年5月9日

本文转载自https://data36.com/sql-for-data-analysis-tutorial-beginners/

如果你想成数据分析师或是数据科学家,那么 SQL 是必须的。在过去的几年中,我已经与许多公司有线业务合作 - 从 5 人创业公司到 5000 多名员工跨国公司,并没有看到一家不会以某种方式使用SQL进行数据分析(以及更多的事情)的公司。

SQL简单并且容易理解。因而,不只是工程师、开发者、数据分析师或数据科学家可以使用它,而是任何愿意花费几天来学习和练习它的人。

我已经创建了这个 SQL 系列,成为有志的数据分析师和数据科学家的最实用和多动手的 SQL 教程。如果你从没有接触过编码、编程、查询,它将从头开始,这并不会是一个问题!

让我们开始吧!

利用 SQL 进行数据分析初学者教程-ep1

注意:因为这是一个实用教程,我鼓励你和我一起编码。如果你这样做,你将需要一个数据服务器来练习。所以我建议你先通过阅读这篇文章。

利用SQL进行数据分析?这是什么?为什么好呢?

SQL代表『结构化查询语言』。 但是我喜欢描述它为「加强版的 Excel」。下面是同一份数据在 Excel 和 SQL:

利用 SQL 进行数据分析初学者教程-ep1

如你所见,SQL 和 Excel 十分相似。它们用具有行和列的二维列表展示数据。两者都非常结构化,非常透明。

不过也有差异。作为初学者,你应该知道两件关于 SQL 的重要事情:

1.第一是性能。虽然 Excel 在小数据集中表现很棒,但是当你使用不同的公式处理 100 k+ 行的文件,它变得十分缓慢和低效。在 SQL 中,甚至超过 10 M+ 行的文件可以很快的处理。(例如,在接下来的利用 SQL进行数据分析文章中,我们将使用一个 7 M+ 行的数据集。)

2.第二是怎样访问你的数据。Excel 主要是图形用户界面(也成为 GUI)。你可以滚动、敲入公式、用光标选择你的范围等等,非常方便。在 SQL 中,你没有这样的界面,你必须使用称为『SQL 查询』来代替。看下面的gif:

利用 SQL 进行数据分析初学者教程-ep1

在 Excel 中求和

利用 SQL 进行数据分析初学者教程-ep1

在 SQL 中求和

因为第一次看到这个,可能感觉到麻烦。但是相信我,一旦你了解 SQL 基础知识,你会发现它比 Excel 更加清晰、更有效率。只提两个有点:在 SQL 中,连接表比 Excel 更简单。同样,使用 SQL 自动化和重复使用脚本也将会变得更加方便。

当你使用 SQL 进行数据分析,你将会使用它(最有可能)进行简单任务:聚合事情、连接数据集、使用简单的统计和数学方法。但是,你可以比以前更有效率执行这些任务和更大的数据集。

Python,R 和 bash怎么样?

如果你已经完成了我之前的 bash 教程 或者你已经参加一些我的在线直播,你可能会问:SQL 比 Python,R 或者 bash 好还是坏?答案是...好吧,这个问题没有明确答案!

一旦你开始在实际生活的数据项目中应用这些语言,你将看到 Python 和 R 在某些方面是表现好的,而 SQL 在其他方面表现好。主要是语法、功能、性能不同...但是,我现在不想进入该主题,因为:

a)我承诺一个使用教程,其主题有点理论(甚至有点哲学)。

b)它还有点先进的东西。

c)在这个水平上,你完全不需要担心它的性能,并且你有可能得到资深数据科学家或者数据工程师的帮助。

注意:如果你真的很好奇,我给你~1小时在这里比较 Python,R,SQL 和 bash。

但是现在,让我们试试吧!

STEP 0 - 安装你自己的 SQL 环境来练习!

注意:如果你已经有自己的 SQL 环境,你可以跳到STEP-获得数据!

首先,请仔细阅读这篇文章。它是关于如何一步一步设置你自己的数据服务和安装 bash,Python,R 和 SQL 的教程。

注意:在我的『利用 SQL 进行数据分析』文章中,我将使用 postgreSQL!还有其他类型的 SQL 语言(例如,另一个众所周知的开源语言 mySQL)。好消息是,所有的 SQL 语言都非常相似 -- 如果你学习 postgreSQL,则需要几个小时(甚至几分钟)才能适应另一个。我选择了 postgreSQL,因为它很受欢迎(许多在线企业都在使用它),同时它被称为最先进的开源 SQL 语言。

如果你通过上述链接的文章,请仔细检查,如果你有以下3件事情:

1.具有终端(或 iTerm)访问权限的数据服务器。

2.PostgreSQL 安装在你的数据服务器上。

3.你的计算机上的Pgadmin4(或SQL Workbench)。

如果缺少某些内容,请再次阅读:安装 bash,Python,R 和 SQL!

注意:作为一个 SQL 查询工具,相比于 pgadmin4,我更喜欢 SQL Workbench,但这是一种品味的问题。在我的利用 SQL 进行数据分析教程中,我将使用 SQL Workbench(以下是有关如何在计算机上安装它的教程),但你可以随意使用 pgadmin4。这不会有什么区别!

STEP 1 – 通过命令行登录你的 SQL 数据库!

太好了!你将在一分钟内编写你的第一个 SQL 查询!首先从命令行访问你的 SQL 数据库!你已经做了一次,我们将重复这个过程:

1.打开终端(或 iTerm)。

2.ssh到你的数据服务器

在我的环境下,我输入:

ssh tomi@[myipadress]

利用 SQL 进行数据分析初学者教程-ep1

3.一旦我登录服务器,我想访问我的 postgreSQL 数据库。因为我已经访问了我的用户,我只需要键入这个命令:

psql -U tomi -d postgres- » psql

是命令本身以及

-U

指定你的用户名(我的为「tomi」),以及

-d

指定你的数据库的名称(我的是 postgres 同样适用于你)。你的提示应改为:

postgres=>

利用 SQL 进行数据分析初学者教程-ep1

完成!你可以完全访问你的 SQL 数据库!   4.作为测试,键入:

\dt

这会列出你所有的数据表。到目前为止,你只有一个数据表,但是这将会马上改变!

利用 SQL 进行数据分析初学者教程-ep1

再次提醒!如果缺少某些东西或者不能运行,请再次阅读:安装 bash,Python,R 和 SQL!

STEP 2 - 获得数据!

在本教程中,我们将使用一个非常小的数据集,称为 zoo。

您可以从这里以原始 .tsv 格式下载,你可以在 Excel 中操作它。如果您已经完成了bash 教程,或者在bash /command line。

但是,继续使用SQL:

1)创建一个表,我们可以向表中载入数据。在我的后续教程中,我将详细解释这里发生了什么,但现在,你只需将这几行代码复制粘贴到终端中:

CREATE TABLE zoo (

利用 SQL 进行数据分析初学者教程-ep1

2)仔细检查表格是否已创建:

\dt

我们有新的数据表:zoo!

利用 SQL 进行数据分析初学者教程-ep1

3)载入数据!

再次说明:我稍后会解释,但是现在,只是复制粘贴这个 SQL 查询:

INSERT INTO zoo (animal,uniq_id,water_need) VALUES

如果一切正常,你会得到这条提醒:

INSERT 0 22

利用 SQL 进行数据分析初学者教程-ep1

最重要的 SQL 语句:SELECT

是时候学习最基本的 SQL 语句。这是:

SELECT * FROM table_name;

每当你在数据上使用读取,过滤,转换,聚合或执行任何操作,你将会使用 SELECT。在这系列教程中,90%的内容将会显示出来,以某种方式修改单一查询。作为开始,我们从 zoo 数据表中 SELECT 任意内容。

SELECT * FROM zoo;

利用 SQL 进行数据分析初学者教程-ep1

我已经得到完整的可读格式的表。(如果要从这个视角中退出,请在键盘上按Q键。)

SELECT * FROM zoo;

我想它甚至不需要一个解释 -- 因为语法本身非常接近英语 - 但是为了以防万一:

SELECT

是主语句,它告诉 SQL 我们想从我们的数据表中读取一些东西。

*

通常是指「一切」 -- 在这种情况下,这意味着我们想选择每一列。

FROM

告诉 SQL,我们要从指定的表中读取数据。

zoo

是表的名称。如果你有更多的表,您可以将其替换为任何其他表名。

;

这是一个 SQL 特定的语法。每个查询都应该用分号关闭。如果您不小心错过了,SQL 将期望您继续查询,不会在屏幕上返回任何内容。

利用 SQL 进行数据分析初学者教程-ep1

从现在起,你将会使用这种语法。

SELECT columns

你可以用实际的列名替换 * 字符。尝试这个查询:

SELECT animal, water_need FROM zoo;

利用 SQL 进行数据分析初学者教程-ep1

(如果要从此视图中退出,请在键盘上按Q键。)

确切地说,你所期望的是:你的屏幕上列出了「animal」和「waterneed」列,而不是「uniqid」。

这样可以 SELECT 任何列。你只需要用逗号分隔指定的列名。

你也可以这样做:

SELECT animal, animal, animal FROM zoo;

利用 SQL 进行数据分析初学者教程-ep1

你会看到同一列多次...但是,因为这是没有意义的,我建议只是根本不这样做。

显示数据的前几行 -- LIMIT 从句

现在我们正在使用 22 行的数据表。在「利用 SQL 进行数据分析」系列的下一集中,我们将使用一个 7 M+ 行数据文件。这是一个很大的变化,在这种情况下,每次都在屏幕上打印所有数据是不合理的,而是获取前几行的小样本。为此,使用 LIMIT 从句 - 这是之前介绍的「基础查询」顶部的一个小「扩展」:

SELECT * FROM zoo LIMIT 10;

这将仅打印前10行。(记住它是如何在 bash 中完成的?这是

head -10

命令。)

利用 SQL 进行数据分析初学者教程-ep1

当然,你可以决定要打印多少行,并在 LIMIT 之后指定!

过滤指定行 -- WHERE从句

基于数值,你可以用 WHERE 从句选择特定的行。例如:

SELECT * FROM zoo WHERE animal = 'elephant';

利用 SQL 进行数据分析初学者教程-ep1

SELECT * FROM zoo

-»这是「基础查询」

WHERE

-» 这告诉 SQL 你想过滤一些东西

animal = 'elephant'

-» animal 是你正在寻找给定值的列名。而 elephant 是值本身。在 SQL 中,你必须添加列名,寻找值。

;

-» 永远不要忘记分号!

在利用 SQL 进行数据分析系列的下一集中,我将详细介绍如何充分利用 WHERE!现在,如果你知道这是为了过滤行,便足够了。

自我测试#1

这是一个介绍性的文章,所以这第一个任务也将是相当容易的:

从 zoo 表中选择前 3 个 zebra!

该解或多或少是本文的总结!

. . . 准备?

这是我的解决方案:

SELECT * FROM zoo WHERE animal = 'zebra' LIMIT 3;

利用 SQL 进行数据分析初学者教程-ep1

SQL 很容易,对吧?

还有一件事:语法...

稍后,我将向你展示一些最佳实践,以及如何保持 SQL 查询的清洁和高效,但在第一篇文章中,我仅强调两件事情:

  1. 所有的查询都应以分号(;)结尾。如果你不小心错过了,SQL 将期望您继续查询,不会在屏幕上返回任何内容。例如:

  2. 当谈到SQL关键字(SELECT,WHERE,LIMIT等),SQL 并不区分大小写。例如:

postgres=> SELECT * FROM zoo;

postgres=> SELECT * FROM zoo

postgres->

  1. 这不是很好...这样更好:

SELECT * FROM ZOO WHERE ANIMAL = 'ELEPHANT';

  1. –» DOES NOT WORK

SELECT * FROM ZOO WHERE ANIMAL = 'elephant';

  1. –» WORKS

SELECT * FROM zoo WHERE animal = 'elephant';

  1. –» WORKS

select * from zoo;

  1. 表名,列名和值的区分大小写是你设置的问题。在我们当前的设置(使用postgreSQL)中,表名和列名不区分大小写,但是字段值是。例如。

SELECT * FROM zoo;

  1. 工作原理如下:

请注意,按照惯例上大多数人使用大写 SQL 关键字(SELECT,WHERE,LIMIT等)。它有助于阅读你的代码。

结论

相当不错的学习和使用 SQL 进行数据分析!恭喜!现在你可以写你的第一个非常基本的 SQL 查询...但这只是开始!让我们继续下一集,并学习如何使用 WHERE 从句从数据集中过滤东西。

如果你不想错过下一集,并且也想获得有关即将到来的网络研讨会的信息,请订阅我的每周通讯

相关阅读

关键词不能为空
极力推荐

电脑蓝屏_电脑怎么了_win7问题_win10问题_设置问题_文件问题_上犹电脑信息网

关于我们