1
0
mirror of https://github.com/django/django.git synced 2024-12-22 17:16:24 +00:00

Fixed #34873 -- Added QuerySet.explain() support for GENERIC_PLAN option on PostgreSQL 16+.

This commit is contained in:
Mariusz Felisiak 2023-09-26 12:05:26 +02:00 committed by GitHub
parent 357365a64e
commit f9e9526800
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 13 additions and 1 deletions

View File

@ -134,6 +134,10 @@ class DatabaseFeatures(BaseDatabaseFeatures):
def is_postgresql_15(self):
return self.connection.pg_version >= 150000
@cached_property
def is_postgresql_16(self):
return self.connection.pg_version >= 160000
has_bit_xor = property(operator.attrgetter("is_postgresql_14"))
supports_covering_spgist_indexes = property(operator.attrgetter("is_postgresql_14"))
supports_unlimited_charfield = True

View File

@ -31,6 +31,7 @@ class DatabaseOperations(BaseDatabaseOperations):
"ANALYZE",
"BUFFERS",
"COSTS",
"GENERIC_PLAN",
"SETTINGS",
"SUMMARY",
"TIMING",

View File

@ -3076,6 +3076,10 @@ adverse effects on your database. For example, the ``ANALYZE`` flag supported
by MariaDB, MySQL 8.0.18+, and PostgreSQL could result in changes to data if
there are triggers or if a function is called, even for a ``SELECT`` query.
.. versionchanged:: 5.1
Support for the ``generic_plan`` option on PostgreSQL 16+ was added.
.. _field-lookups:
``Field`` lookups

View File

@ -168,7 +168,8 @@ Migrations
Models
~~~~~~
* ...
* :meth:`.QuerySet.explain` now supports the ``generic_plan`` option on
PostgreSQL 16+.
Requests and Responses
~~~~~~~~~~~~~~~~~~~~~~

View File

@ -85,6 +85,8 @@ class ExplainTests(TestCase):
{"settings": True},
{"analyze": True, "wal": True},
]
if connection.features.is_postgresql_16:
test_options.append({"generic_plan": True})
for options in test_options:
with self.subTest(**options), transaction.atomic():
with CaptureQueriesContext(connection) as captured_queries: