Fixed #16255 -- Raised minimum PostgreSQL version supported to 8.2.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@16423 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
b2f5efc6ac
commit
b870bf6b9a
|
@ -141,20 +141,11 @@ class DatabaseWrapper(BaseDatabaseWrapper):
|
||||||
cursor.execute("SET TIME ZONE %s", [settings_dict['TIME_ZONE']])
|
cursor.execute("SET TIME ZONE %s", [settings_dict['TIME_ZONE']])
|
||||||
if not hasattr(self, '_version'):
|
if not hasattr(self, '_version'):
|
||||||
self.__class__._version = get_version(cursor)
|
self.__class__._version = get_version(cursor)
|
||||||
if self._version[0:2] < (8, 0):
|
|
||||||
# No savepoint support for earlier version of PostgreSQL.
|
|
||||||
self.features.uses_savepoints = False
|
|
||||||
if self.features.uses_autocommit:
|
if self.features.uses_autocommit:
|
||||||
if self._version[0:2] < (8, 2):
|
# FIXME: Eventually we'll enable this by default for
|
||||||
# FIXME: Needs extra code to do reliable model insert
|
# versions that support it, but, right now, that's hard to
|
||||||
# handling, so we forbid it for now.
|
# do without breaking other things (#10509).
|
||||||
from django.core.exceptions import ImproperlyConfigured
|
self.features.can_return_id_from_insert = True
|
||||||
raise ImproperlyConfigured("You cannot use autocommit=True with PostgreSQL prior to 8.2 at the moment.")
|
|
||||||
else:
|
|
||||||
# FIXME: Eventually we're enable this by default for
|
|
||||||
# versions that support it, but, right now, that's hard to
|
|
||||||
# do without breaking other things (#10509).
|
|
||||||
self.features.can_return_id_from_insert = True
|
|
||||||
return CursorWrapper(cursor)
|
return CursorWrapper(cursor)
|
||||||
|
|
||||||
def _enter_transaction_management(self, managed):
|
def _enter_transaction_management(self, managed):
|
||||||
|
|
|
@ -84,23 +84,13 @@ class DatabaseOperations(BaseDatabaseOperations):
|
||||||
|
|
||||||
def sql_flush(self, style, tables, sequences):
|
def sql_flush(self, style, tables, sequences):
|
||||||
if tables:
|
if tables:
|
||||||
if self.postgres_version[0:2] >= (8,1):
|
# Perform a single SQL 'TRUNCATE x, y, z...;' statement. It allows
|
||||||
# Postgres 8.1+ can do 'TRUNCATE x, y, z...;'. In fact, it *has to*
|
# us to truncate tables referenced by a foreign key in any other
|
||||||
# in order to be able to truncate tables referenced by a foreign
|
# table.
|
||||||
# key in any other table. The result is a single SQL TRUNCATE
|
sql = ['%s %s;' % \
|
||||||
# statement.
|
(style.SQL_KEYWORD('TRUNCATE'),
|
||||||
sql = ['%s %s;' % \
|
style.SQL_FIELD(', '.join([self.quote_name(table) for table in tables]))
|
||||||
(style.SQL_KEYWORD('TRUNCATE'),
|
)]
|
||||||
style.SQL_FIELD(', '.join([self.quote_name(table) for table in tables]))
|
|
||||||
)]
|
|
||||||
else:
|
|
||||||
# Older versions of Postgres can't do TRUNCATE in a single call, so
|
|
||||||
# they must use a simple delete.
|
|
||||||
sql = ['%s %s %s;' % \
|
|
||||||
(style.SQL_KEYWORD('DELETE'),
|
|
||||||
style.SQL_KEYWORD('FROM'),
|
|
||||||
style.SQL_FIELD(self.quote_name(table))
|
|
||||||
) for table in tables]
|
|
||||||
|
|
||||||
# 'ALTER SEQUENCE sequence_name RESTART WITH 1;'... style SQL statements
|
# 'ALTER SEQUENCE sequence_name RESTART WITH 1;'... style SQL statements
|
||||||
# to reset sequence indices
|
# to reset sequence indices
|
||||||
|
@ -171,17 +161,10 @@ class DatabaseOperations(BaseDatabaseOperations):
|
||||||
def check_aggregate_support(self, aggregate):
|
def check_aggregate_support(self, aggregate):
|
||||||
"""Check that the backend fully supports the provided aggregate.
|
"""Check that the backend fully supports the provided aggregate.
|
||||||
|
|
||||||
The population and sample statistics (STDDEV_POP, STDDEV_SAMP,
|
|
||||||
VAR_POP, VAR_SAMP) were first implemented in Postgres 8.2.
|
|
||||||
|
|
||||||
The implementation of population statistics (STDDEV_POP and VAR_POP)
|
The implementation of population statistics (STDDEV_POP and VAR_POP)
|
||||||
under Postgres 8.2 - 8.2.4 is known to be faulty. Raise
|
under Postgres 8.2 - 8.2.4 is known to be faulty. Raise
|
||||||
NotImplementedError if this is the database in use.
|
NotImplementedError if this is the database in use.
|
||||||
"""
|
"""
|
||||||
if aggregate.sql_function in ('STDDEV_POP', 'STDDEV_SAMP', 'VAR_POP', 'VAR_SAMP'):
|
|
||||||
if self.postgres_version[0:2] < (8,2):
|
|
||||||
raise NotImplementedError('PostgreSQL does not support %s prior to version 8.2. Please upgrade your version of PostgreSQL.' % aggregate.sql_function)
|
|
||||||
|
|
||||||
if aggregate.sql_function in ('STDDEV_POP', 'VAR_POP'):
|
if aggregate.sql_function in ('STDDEV_POP', 'VAR_POP'):
|
||||||
if self.postgres_version[0:2] == (8,2):
|
if self.postgres_version[0:2] == (8,2):
|
||||||
if self.postgres_version[2] is None or self.postgres_version[2] <= 4:
|
if self.postgres_version[2] is None or self.postgres_version[2] <= 4:
|
||||||
|
|
|
@ -16,21 +16,9 @@ documentation or reference manuals.
|
||||||
PostgreSQL notes
|
PostgreSQL notes
|
||||||
================
|
================
|
||||||
|
|
||||||
.. versionchanged:: 1.3
|
.. versionchanged:: 1.4
|
||||||
|
|
||||||
Django supports PostgreSQL 8.0 and higher. If you want to use
|
Django supports PostgreSQL 8.2 and higher.
|
||||||
:ref:`database-level autocommit <postgresql-autocommit-mode>`, a
|
|
||||||
minimum version of PostgreSQL 8.2 is required.
|
|
||||||
|
|
||||||
.. admonition:: Improvements in recent PostgreSQL versions
|
|
||||||
|
|
||||||
PostgreSQL 8.0 and 8.1 `will soon reach end-of-life`_; there have
|
|
||||||
also been a number of significant performance improvements added
|
|
||||||
in recent PostgreSQL versions. Although PostgreSQL 8.0 is the minimum
|
|
||||||
supported version, you would be well advised to use a more recent
|
|
||||||
version if at all possible.
|
|
||||||
|
|
||||||
.. _will soon reach end-of-life: http://wiki.postgresql.org/wiki/PostgreSQL_Release_Support_Policy
|
|
||||||
|
|
||||||
PostgreSQL 8.2 to 8.2.4
|
PostgreSQL 8.2 to 8.2.4
|
||||||
-----------------------
|
-----------------------
|
||||||
|
|
|
@ -376,3 +376,14 @@ Old styles of calling ``cache_page`` decorator
|
||||||
Some legacy ways of calling :func:`~django.views.decorators.cache.cache_page`
|
Some legacy ways of calling :func:`~django.views.decorators.cache.cache_page`
|
||||||
have been deprecated, please see the docs for the correct way to use this
|
have been deprecated, please see the docs for the correct way to use this
|
||||||
decorator.
|
decorator.
|
||||||
|
|
||||||
|
Support for PostgreSQL versions older than 8.2
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Django 1.3 dropped support for PostgreSQL versions older than 8.0 and the
|
||||||
|
relevant documents suggested to use a recent version because of performance
|
||||||
|
reasons but more importantly because end of the upstream support periods for
|
||||||
|
releases 8.0 and 8.1 was near (November 2010.)
|
||||||
|
|
||||||
|
Django 1.4 takes that policy further and sets 8.2 as the minimum PostgreSQL
|
||||||
|
version it officially supports.
|
||||||
|
|
Loading…
Reference in New Issue