Type: | enum |
Défaut: | auto |
Contexte: | user |
Redémarrer: | false |
Valeurs: | [auto, force_generic_plan, force_custom_plan] |
Depuis: | 12 |
Les requêtes préparées (soit explicitement préparées soit implicitement générées, par exemple dans PL/pgSQL) peuvent être exécutées en utilisant des plans personnalisés ou génériques. Les plans personnalisés sont de nouveau créés à chaque exécution en utilisant son ensemble spécifique de valeurs de paramètres, alors que les plans génériques ne se basent pas sur les valeurs des paramètres et peuvent être ré-utilisés au fil des exécutions. De ce fait, l'utilisation d'un plan générique permet d'éviter de gâcher du temps de planification mais si le plan idéal dépend fortement des valeurs de paramètres, alors un plan générique pourrait être inefficace. Le choix entre ces options est généralement fait automatiquement mais il peut être forcé avec le paramètre plan_cache_mode
. Les valeurs autorisées sont auto
(valeur par défaut), force_custom_plan
et force_generic_plan
. Ce paramètre est considéré quand un plan en cache va être exécuté, et non pas quand il va être préparé. Pour plus d'informations, voir sql-prepare.
Sur StackOverflow
Sur pgsql-hackers
- Problem, partition pruning for prepared statement with IS NULL clause.
- Re: Problem, partition pruning for prepared statement with IS NULL clause.
- Query results vary depending on the plan cache mode used
- Re: Report planning memory in EXPLAIN ANALYZE
- Re: a wrong index choose when statistics is out of date