

 从补丁 198 开始，Amazon Redshift 将不再支持创建新的 Python UDF。现有的 Python UDF 将继续正常运行至 2026 年 6 月 30 日。有关更多信息，请参阅[博客文章](https://www.amazonaws.cn/blogs/big-data/amazon-redshift-python-user-defined-functions-will-reach-end-of-support-after-june-30-2026/)。

# 使用 SVL\$1QUERY\$1REPORT 视图
<a name="using-SVL-Query-Report"></a>

要使用 [SVL\$1QUERY\$1REPORT](r_SVL_QUERY_REPORT.md) 按切片分析查询摘要信息，请执行以下操作：

1. 运行以下命令以确定查询 ID：

   ```
   select query, elapsed, substring
   from svl_qlog
   order by query
   desc limit 5;
   ```

   检查 `substring` 字段中的截断查询文本来确定哪些 `query` 值代表您的查询。如果您已多次运行查询，请使用具有较低 `elapsed` 值的行中的 `query` 值。这是已编译的行。如果运行多个查询，则可以增大 LIMIT 子句使用的值，以确保将查询包含在内。

1. 从查询的 SVL\$1QUERY\$1REPORT 中选择。按分段、步骤、elapsed\$1time 和行对结果进行排序：

   ```
   select * from svl_query_report where query = MyQueryID order by segment, step, elapsed_time, rows;
   ```

1. 对于每个步骤，检查以查看处理的所有切片数是否与行数大致相同：  
![\[用于运行查询的数据切片列表。每个切片处理的行数大致相同。\]](http://docs.amazonaws.cn/redshift/latest/dg/images/SVL_QUERY_REPORT_rows.png)

   此外，检查以查看所有切片所花费的时间是否大致相同：  
![\[用于运行查询的数据切片列表。每个切片所需的时间大致相同。\]](http://docs.amazonaws.cn/redshift/latest/dg/images/SVL_QUERY_REPORT_elapsed_time.png)

   这些值存在较大的差异可能表明由于此特定查询的分配方式不佳而导致数据分布偏差。有关建议的解决方案，请参阅[非最优数据分配](query-performance-improvement-opportunities.md#suboptimal-data-distribution)。