在 PostgreSQL 中查看 default_statistics_target 的值

51次阅读
没有评论

问题描述

想要在运行 SET default_statistics_target=1000 之前查看 PostgreSQL 中 default_statistics_target 的值。虽然默认值可能是 100,但用户希望能够确认它。用户想知道该值存储在哪里。

解决方案

在进行以下操作之前,请确保您对 PostgreSQL 数据库有足够的了解,并根据需要备份相关数据。

查找 default_statistics_target 的默认值

在 PostgreSQL 中,default_statistics_target 的默认值可以在源代码中找到。您可以在源代码中的特定位置找到这个信息。

  1. 访问 PostgreSQL 源代码仓库
  2. 在源代码中,找到 src/backend/utils/misc/guc.c 文件。
  3. 在该文件中搜索 default_statistics_target,您会找到类似以下的代码片段:
{
    {"default_statistics_target", PGC_USERSET, QUERY_TUNING_OTHER,
    gettext_noop("Sets the default statistics target."),
    gettext_noop("This applies to table columns that have not had a "
                    "column-specific target set via ALTER TABLE SET STATISTICS.")
    },
    &default_statistics_target,
    100, 1, 10000,
    NULL, NULL, NULL
},

在上述代码片段中,您可以看到 default_statistics_target 的默认值为 100。此处的值是在 &default_statistics_target 的第一个参数中定义的。

查看 Stats target 值

要在应用 SET default_statistics_target=1000 之前查看 Stats target 的值,您可以使用 SQL 查询或数据库命令来实现。

通过 SQL 查询查看 Stats target 值

您可以使用以下 SQL 查询来查看不同表的列的 attstattarget 值,这是 PostgreSQL 中 Stats target 的属性:

SELECT attrelid::regclass, attname, attstattarget
FROM pg_attribute
WHERE attstattarget > 0
ORDER BY attstattarget DESC;

通过数据库命令查看 Stats target 值

您还可以使用数据库命令 \d+ 表名 来查看特定表的列属性,其中包括 Stats target 值。例如:

\d+ 表名

请注意,PostgreSQL 在默认情况下不会显示 Stats target 值,除非它与默认值不同。

了解更多关于 Stats target 值的信息

如果您想深入了解关于 Stats target 值的更多信息,您可以阅读一篇与之相关的论文,链接如下:Random sampling for histogram construction: how much is enough?

此外,如果您对 PostgreSQL 的源代码感兴趣,您可以查看源代码文件 src/backend/commands/analyze.c 中的相关部分来了解更多关于 Stats target 值的实现细节。

请注意,操作数据库时,请确保您已经理解相关概念,并遵循最佳实践。

总结

在 PostgreSQL 中,您可以通过查找源代码和使用 SQL 查询或数据库命令来查看和确认 default_statistics_targetStats target 的值。了解这些值的含义以及如何正确设置它们对于优化查询和性能调整非常重要。在操作数据库之前,请确保您已经充分了解所涉及的概念和操作。

正文完