云贝教育 |【PostgreSQL PGCE-091题目解析22】PG中,autovacuum可以自动地分析表,并收集表的统计信息。

本文主要是介绍云贝教育 |【PostgreSQL PGCE-091题目解析22】PG中,autovacuum可以自动地分析表,并收集表的统计信息。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

考试科目:PGCE-E-091

考试题量:44 道单项选择题、29 道多项选择题(每题 2 分)

通过分数:60%

考试时间:60min

本文为云贝教育刘峰(微信:yunbee_DBA)原创,请尊重知识产权,转发请注明出处,不接受任何抄袭、演绎和未经注明出处的转载。


PG中,autovacuum可以自动地分析表,并收集表的统计信息。

A 正确

B 错误

参考答案:A


解析

autovacuum会做两件事

  • autovacuum_vacuum

  • autovacuum_analyze

autovacuum_vacuum_threshold:默认50。

与autovacuum_vacuum_scale_factor配合使用, autovacuum_vacuum_scale_factor默认值为20%。

当update,delete的tuples数量超过autovacuum_vacuum_scale_factor*table_size+autovacuum_vacuum_threshold时,进行vacuum。如果要使vacuum工作勤奋点,则将此值改小。

testdb=# show autovacuum_vacuum_threshold;autovacuum_vacuum_threshold 
-----------------------------50
(1 row)
testdb=# show autovacuum_vacuum_scale_factor;autovacuum_vacuum_scale_factor 
--------------------------------0.2
(1 row)

autovacuum_analyze_threshold:默认50。

与autovacuum_analyze_scale_factor配合使用, autovacuum_analyze_scale_factor默认10%。

当update,insert,delete的tuples数量超过autovacuum_analyze_scale_factor*table_size+autovacuum_analyze_threshold时,进行analyze。

testdb=# show autovacuum_analyze_threshold;autovacuum_analyze_threshold 
------------------------------50
(1 row)
testdb=# show autovacuum_analyze_scale_factor;autovacuum_analyze_scale_factor 
---------------------------------0.1
(1 row)

实验过程

1、创建实验表

postgre=# create table t2(id int,name text);
CREATE TABLE
postgre=# insert into t2 values(generate_series(1,1000),'aaaaa'||generate_series(1,1000));
INSERT 0 1000

2、查看表t2的信息

cmdb=# select relname,reltuples,relpages from pg_class where relname='t2';relname | reltuples | relpages 
---------+-----------+----------t2      |         -1|      0
(1 row)

3、计算触发条件

autovacuum Vacuum=0.2*1000+50=250;
autovacuum ANALYZE=0.1*1000+50=150;

4、修改t2表151行

postgre=#  update t2 set name='bbb' where id<152; 
UPDATE 151 postgre=# SELECT schemaname, 
n_tup_ins as "inserts", 
n_tup_upd as "updates", 
n_tup_del as "deletes", 
n_live_tup as "live_tuples",n_dead_tup as "dead_tuples", 
last_vacuum, last_autovacuum, 
last_analyze, 
last_autoanalyze FROM pg_stat_user_tables WHERE relname = 't2'; 
-[ RECORD 1 ]----+------------------------------ 
schemaname | public inserts | 1000 updates | 151 deletes | 0 live_tuples | 1000 dead_tuples | 151 last_vacuum | last_autovacuum | last_analyze | last_autoanalyze | 2023-11-01 21:01:14.482775+08

以上实验可以确认,在修改151条数据时,触发了autovacuum ANALYZE

5、查看统计信息

testdb=# select relname,reltuples,relpages from pg_class where relname='t3';relname | reltuples | relpages 
---------+-----------+----------t3      |      1000 |        7
(1 row)

可以看到在达到autovacuum ANALYZE的阀值,统计信息己被收集。

这篇关于云贝教育 |【PostgreSQL PGCE-091题目解析22】PG中,autovacuum可以自动地分析表,并收集表的统计信息。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/467310

相关文章

Python中配置文件的全面解析与使用

《Python中配置文件的全面解析与使用》在Python开发中,配置文件扮演着举足轻重的角色,它们允许开发者在不修改代码的情况下调整应用程序的行为,下面我们就来看看常见Python配置文件格式的使用吧... 目录一、INI配置文件二、YAML配置文件三、jsON配置文件四、TOML配置文件五、XML配置文件

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

Ubuntu 22.04 服务器安装部署(nginx+postgresql)

《Ubuntu22.04服务器安装部署(nginx+postgresql)》Ubuntu22.04LTS是迄今为止最好的Ubuntu版本之一,很多linux的应用服务器都是选择的这个版本... 目录是什么让 Ubuntu 22.04 LTS 变得安全?更新了安全包linux 内核改进一、部署环境二、安装系统

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解

MySQL表锁、页面锁和行锁的作用及其优缺点对比分析

《MySQL表锁、页面锁和行锁的作用及其优缺点对比分析》MySQL中的表锁、页面锁和行锁各有特点,适用于不同的场景,表锁锁定整个表,适用于批量操作和MyISAM存储引擎,页面锁锁定数据页,适用于旧版本... 目录1. 表锁(Table Lock)2. 页面锁(Page Lock)3. 行锁(Row Lock

Java中实现订单超时自动取消功能(最新推荐)

《Java中实现订单超时自动取消功能(最新推荐)》本文介绍了Java中实现订单超时自动取消功能的几种方法,包括定时任务、JDK延迟队列、Redis过期监听、Redisson分布式延迟队列、Rocket... 目录1、定时任务2、JDK延迟队列 DelayQueue(1)定义实现Delayed接口的实体类 (

shell脚本自动删除30天以前的文件(最新推荐)

《shell脚本自动删除30天以前的文件(最新推荐)》该文章介绍了如何使用Shell脚本自动删除指定目录下30天以前的文件,并通过crontab设置定时任务,此外,还提供了如何使用Shell脚本删除E... 目录shell脚本自动删除30天以前的文件linux按照日期定时删除elasticsearch索引s

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动