使用 SQL Runner 创建查询和探索

SQL Runner 提供了一种直接访问数据库的方法,并以各种方式利用该访问。使用 SQL Runner,您可以轻松地在架构中导航表、使用 SQL 查询进行临时探索、对数据运行预先编写的描述性查询、查看 SQL Runner 历史记录、下载结果、共享查询、以派生表的形式添加到 LookML 项目中,以及执行其他实用任务。

本页面介绍如何在 SQL Runner 中运行查询创建临时探索,以及如何使用 SQL Runner 调试查询。有关信息,请参阅以下其他文档页面:

在 SQL Runner 中运行查询

如需对数据库运行查询,您可以从头开始编写 SQL 查询使用探索功能创建查询针对 LookML 模型运行查询。您还可以使用历史记录重新运行之前的查询。

从头开始编写 SQL 查询

您可以使用 SQL Runner 针对数据库编写和运行您自己的 SQL 查询。Looker 会将查询传递给您的数据库,就像您编写查询一样,因此请确保 SQL 查询的语法对您的数据库方言有效。例如,每种方言都有略有不同的 SQL 函数,这些函数具有应传递给该函数的特定参数。

  1. 查询栏下方的文本框中输入 SQL 查询。
  2. (可选)从字段列表中选择表名称或字段,以将其包含在游标位置处的查询中。
  3. 选择运行以对您的数据库运行查询。
  4. 结果区域中查看结果。SQL Runner 最多将加载 5,000 行查询结果集。对于支持流式传输的 SQL 方言,您可以下载结果以查看整个结果集。

某些 SQL 程序允许您连续运行多个查询。但在 SQL Runner 中,一次只能运行一个查询。SQL Runner 的查询还具有 65,535 个字符的限制,包括空格。

运行查询后,您可以将查询添加到项目中获取派生表的 LookML共享查询

您还可以使用 SQL Runner 处理新查询或测试现有查询。SQL Runner 错误突出显示有助于测试和调试查询。

使用“探索”功能创建 SQL 查询

您还可以使用“探索”功能创建查询,然后获取该查询的 SQL 命令以在 SQL Runner 中使用:

  1. 在“探索”中,从数据栏中选择 SQL 标签页。
  2. SQL 查询将显示在数据栏下方。
  3. 选择在 SQL Runner 中打开Explain in SQL Runner,以在 SQL Runner 中打开查询。

将查询添加到 Query 栏下方的文本框中后,您可以选择 Run 来查询数据库。或者,您可以修改查询,然后运行新查询。

使用 SQL Runner 创建可视化

如果您的 Looker 管理员已启用 SQL Runner Vis 实验室功能,则您可以直接在 SQL Runner 中创建可视化。

启用 SQL Runner Vis 后,系统会重新整理 SQL Runner 面板。可视化面板显示在顶部,结果面板显示在中间,查询面板显示在底部。

  1. 创建并运行 SQL 查询后,您可以打开可视化标签页来查看可视化图表并选择可视化类型,就像在“探索”页面上一样
  2. 您可以使用设置菜单修改可视化图表。
  3. 您可以通过共享网址来共享使用 SQL Runner 创建的可视化图表。系统将保存您使用可视化图表的设置菜单进行的任何自定义,并且该链接不会更改。

关于 SQL Runner 可视化的工作原理,您需要注意以下几点:

  • 结果表格和可视化图表会将任何数字字段解读为测量。
  • 结果表和可视化图表中始终使用完整字段名称。因此,设置菜单中的显示完整字段名称选项无效。
  • 如需使用自定义字段、表计算、数据透视、列总计和小计,请通过 SQL Runner 查询进行探索
  • SQL Runner 可视化图表不支持静态地图(区域)可视化图表,但支持使用纬度和经度数据(地图和静态地图(点)可视化图表)的地图。
  • SQL Runner 可视化图表不支持时间轴可视化。

数据透视维度

您可以在 SQL Runner 可视化中将查询结果修改为按一个或多个维度进行数据透视。要透视字段,请执行以下操作:

  1. 结果区域中选择列的齿轮菜单以显示列选项。
  2. 选择数据透视列

透视结果会显示在 SQL Runner 可视化图表中。

Results 区域中的结果并非以透视法显示。

逆透视结果,请选择透视列的齿轮菜单,然后选择逆透视列

更改字段类型

在显示查询的结果和可视化图表时,SQL Runner 会自动将任何数字字段解释为测量,并将任何非数字字段解释为维度。您可以替换默认字段类型并将维度转换为测量,反之亦然,具体操作步骤如下:

  1. 结果区域中选择列的齿轮菜单以显示列选项。
  2. 选择转换为维度转换为测量可更改字段类型。

可视化图表将显示新的字段类型。

针对 LookML 模型运行查询

您可以使用 SQL Runner 针对 LookML 模型编写和运行 SQL 查询,而不是直接针对数据库运行。针对模型构建查询时,您可以使用 LookML 替代运算符,例如 ${view_name.field_name}${view_name.SQL_TABLE_NAME}。这样可以节省时间,例如构建查询以对派生表进行问题排查时。

Looker 会解析所有 LookML 替代内容,然后将查询传递给数据库,因此查询应使用适用于您的数据库方言的有效 SQL。例如,每种方言都有略有不同的 SQL 函数,这些函数具有应传递给该函数的特定参数。

如需在 SQL Runner 中针对 LookML 模型运行查询,请执行以下操作:

  1. 选择模型标签页。
  2. 选择要查询的模型。
  3. 数据栏下方的文本框中,使用 LookML 字段输入您的 SQL 查询。
  4. (可选)在视图列表中选择一个视图,将该视图添加到查询的光标位置处。
  5. 要查看某个视图中的字段列表,请在视图部分中选择该视图。(可选)您可以在字段列表中选择一个字段,将其包含在查询的光标位置处。
  6. 准备好的 SQL 查询区域,您可以查看在将任何 LookML 替代内容转换为 SQL 后生成的 SQL 查询。
  7. 选择运行以针对您的模型运行查询。
  8. 结果区域中查看结果。SQL Runner 最多可加载 5,000 行查询结果集。对于支持流式传输的 SQL 方言,您可以下载结果以查看整个结果集。

您可以使用 SQL Runner 处理新查询、测试现有查询,或从结果中打开新的探索。SQL Runner 错误突出显示有助于测试和调试查询。

如果您喜欢某个查询,可以共享该查询,甚至可以将该查询添加到 LookML 项目中

从 SQL Runner 查看字段的 LookML

模型标签页的字段列表中,您还可以查看字段的 LookML。将鼠标悬停在字段列表中的字段上,然后选择字段名称右侧的 Looker 图标。

Looker 会打开 LookML IDE,并加载用于定义该字段的文件。

SQL Runner 历史记录

您还可以查看在 SQL Runner 中运行的所有查询的近期历史记录。

要查看历史记录,请选择导航窗格顶部的历史记录标签页。SQL Runner 显示在数据库连接上运行的所有查询。红色表示由于发生错误而未运行的查询。

选择历史记录中的某个查询以将该查询填充到 SQL Runner 中,然后选择运行以重新运行查询。

对查询进行排序

表的排序顺序由已排序的字段名称旁边有一个向上或向下箭头表示,具体取决于结果是升序还是降序。您可以按住 Shift 键,然后按所需的排序顺序选择列标题,从而按多个列进行排序。此外,字段的排序顺序还通过以下方式表示:用于区分其排序依据与其他字段的排序顺序的数字、显示排序方向(升序或降序)的字段名称旁的箭头,以及将鼠标悬停在字段名称上时显示的弹出式窗口。

如需了解详情和查看示例,请参阅在 Looker 中探索数据文档页面的对数据进行排序部分。

共享查询

您可以将 SQL Runner 中的查询与另一个具有 SQL Runner 访问权限的用户共享。要分享查询,请复制浏览器地址栏中的网址。

正在下载结果

运行 SQL 查询后,您能够以各种格式下载结果。

  1. SQL 查询框中编写查询。(此时您无需在 SQL Runner 中运行查询。)
  2. 从右上角的齿轮菜单中选择下载
  3. 选择下载的文件格式(文本文件、CSV、JSON 等)。
  4. 选择在浏览器中打开即可在新的浏览器窗口中查看结果,或选择下载,将结果下载到计算机上的文件中。

    当您选择在浏览器中打开下载后,Looker 会重新运行查询,然后执行下载。

对于支持流的 SQL 方言,SQL Runner 下载选项将下载整个结果集。对于不支持流处理的 SQL 方言,SQL Runner 下载选项将仅下载结果部分中显示的查询行(最多 5,000 行)。

复制列值

您可以从 SQL Runner 的 Results 部分复制列值。选择列的齿轮菜单,以将值复制到剪贴板。在此处,您可以将列值粘贴到文本文件、Excel 电子表格或其他位置。

如果您的 Looker 管理员已启用 SQL Runner Vis 实验室功能,则列齿轮菜单中还有其他选项:

您还可以在结果表格中手动移动、固定列和resize

SQL Runner 查询的费用估算

对于 BigQueryMySQLAmazon RDS for MySQLSnowflakeAmazon RedshiftAmazon AuroraPostgreSQL、Cloud SQL for PostgreSQL 和 Microsoft Azure PostgreSQL 连接,SQL Runner 可提供查询费用的估算值。输入 SQL 查询后,SQL Runner 将计算查询需要的数据量,并在 Run 按钮附近显示相关信息。

对于 BigQuery、MySQL 和 Amazon RDS for MySQL 连接,费用估算始终处于启用状态。对于 Snowflake、Amazon Redshift、Amazon Aurora、PostgreSQL、Cloud SQL for PostgreSQL 和 Microsoft Azure PostgreSQL 数据库连接,您必须为连接启用费用估算选项。您可以在创建连接时启用费用估算。对于现有连接,您可以从 Looker 管理面板的 Database(数据库)部分的 Connections 页面中修改连接

创建临时探索

在 SQL Runner 中,您可以通过为 SQL 查询或数据库表创建临时探索来快速了解数据。您可以使用 Looker 探索来选择字段、添加过滤条件、直观呈现结果,以及创建 SQL 查询。

您可以通过以下两种方式从 SQL Runner 打开临时探索:

  • 从 SQL Runner 的查询结果中探索
  • 从 SQL Runner 的表列表中探索

从 SQL Runner 查询结果中探索

借助 SQL Runner,您可以从 SQL 查询打开探索。这将根据使用 SQL Runner 编写的查询创建一个临时探索。这样,您就可以测试查询返回的内容,并直观呈现结果。这可用于任何查询,但对于测试您计划用于派生表的查询,尤为有用。

如果您的 Looker 管理员已启用 SQL Runner Vis 实验室功能,那么您可以直接在 SQL Runner 中创建可视化内容

  1. 使用 SQL Runner 创建要使用的 SQL 查询。
  2. 从右上角的齿轮菜单中选择探索。系统随即会将您转到新的“探索”页面,您可以在其中探索 SQL 查询,就像是模型中已保存的表一样。
  3. 您可以将该网址复制到此探索中以便分享。
  4. 如需直接从此处将此查询添加为项目中的派生表,请选择将视图添加到项目

在 SQL Runner 中探索时创建自定义字段

如果您可以访问自定义字段功能,则可以使用自定义字段在 SQL Runner 中直观呈现未建模字段。如上一部分所述,从齿轮菜单中选择探索。然后,在字段选择器中按以下步骤操作:

探索 SQL Runner 中列出的表

使用数据库标签页中的探索表选项,为连接中的任何表创建临时探索。这样,您就可以在对表建模之前对表使用 Looker,就像探索 LookML 视图一样探索表。

打开表格的“探索”后,您可以决定是否将表格添加到您的项目中。您还可以使用“探索”的 SQL 标签页查看 Looker 发送到数据库的 SQL 查询,然后使用在 SQL Runner 中打开按钮将查询重新置于 SQL Runner 中。

  1. 选择数据库标签页。
  2. 在 SQL Runner 中,选择表的齿轮图标,然后选择 Explore Table
  3. Looker 会生成一个包含表视图的临时模型,然后显示“探索”。
  4. Looker 为表中的每一列提供了一个维度字段。(这与 Looker 在项目开始时生成模型的方式相同。)
  5. Looker 会自动为所有日期字段添加时间范围。
  6. Looker 还包含计数衡量功能。

使用 Explore Table 选项时,没有与“Explore”关联的 LookML 文件,它只是表的临时视图。

使用 SQL Runner 进行调试

SQL Runner 也是检查查询中的 SQL 错误的实用工具。

突出显示 SQL Runner 错误

SQL Runner 会在 SQL 命令中突出显示错误的位置,并在错误消息中包含错误的位置:

提供的位置信息因数据库方言而异。例如,MySQL 提供包含错误的行号,而 Redshift 提供错误的字符位置。其他数据库方言可能具有上述某种行为或其他行为。

SQL Runner 还会突出显示 SQL 命令中第一个语法错误的位置,方法是为其添加红色下划线,并使用 x 标记该行。将鼠标悬停在 x 上即可查看该错误的详细信息。解决此问题后,选择运行以查看查询中是否还有其他错误。

使用 SQL Runner 检查“探索”中的错误

如果您在“探索”中遇到 SQL 语法错误,可以使用 SQL Runner 确定错误位置和错误类型,例如拼写错误或缺少命令。

  1. 在“探索”中,选择数据栏的 SQL 标签页
  2. 选择在 SQL Runner 中打开,以在 SQL Runner 中打开查询。

这会将探索生成的 SQL 复制到 SQL Runner。如所示,SQL Runner 会突出显示 SQL 命令中的错误位置,并在错误消息中包含错误的位置。然后,您可以在 SQL Runner 中进行更改并重新运行查询,直到更正错误。

使用 SQL Runner 检查派生表中的错误

如需了解如何使用 SQL Runner 检查派生表中的 SQL 错误,请参阅使用 SQL Runner 测试派生表 Looker 社区帖子。