mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #19968 -- Dropped support for PostgreSQL < 8.4.
This commit is contained in:
		| @@ -9,7 +9,7 @@ class DatabaseOperations(BaseDatabaseOperations): | |||||||
|         super(DatabaseOperations, self).__init__(connection) |         super(DatabaseOperations, self).__init__(connection) | ||||||
|  |  | ||||||
|     def date_extract_sql(self, lookup_type, field_name): |     def date_extract_sql(self, lookup_type, field_name): | ||||||
|         # http://www.postgresql.org/docs/8.0/static/functions-datetime.html#FUNCTIONS-DATETIME-EXTRACT |         # http://www.postgresql.org/docs/current/static/functions-datetime.html#FUNCTIONS-DATETIME-EXTRACT | ||||||
|         if lookup_type == 'week_day': |         if lookup_type == 'week_day': | ||||||
|             # For consistency across backends, we return Sunday=1, Saturday=7. |             # For consistency across backends, we return Sunday=1, Saturday=7. | ||||||
|             return "EXTRACT('dow' FROM %s) + 1" % field_name |             return "EXTRACT('dow' FROM %s) + 1" % field_name | ||||||
| @@ -34,7 +34,7 @@ class DatabaseOperations(BaseDatabaseOperations): | |||||||
|         return '(%s)' % conn.join([sql, 'interval \'%s\'' % mods]) |         return '(%s)' % conn.join([sql, 'interval \'%s\'' % mods]) | ||||||
|  |  | ||||||
|     def date_trunc_sql(self, lookup_type, field_name): |     def date_trunc_sql(self, lookup_type, field_name): | ||||||
|         # http://www.postgresql.org/docs/8.0/static/functions-datetime.html#FUNCTIONS-DATETIME-TRUNC |         # http://www.postgresql.org/docs/current/static/functions-datetime.html#FUNCTIONS-DATETIME-TRUNC | ||||||
|         return "DATE_TRUNC('%s', %s)" % (lookup_type, field_name) |         return "DATE_TRUNC('%s', %s)" % (lookup_type, field_name) | ||||||
|  |  | ||||||
|     def datetime_extract_sql(self, lookup_type, field_name, tzname): |     def datetime_extract_sql(self, lookup_type, field_name, tzname): | ||||||
| @@ -43,7 +43,7 @@ class DatabaseOperations(BaseDatabaseOperations): | |||||||
|             params = [tzname] |             params = [tzname] | ||||||
|         else: |         else: | ||||||
|             params = [] |             params = [] | ||||||
|         # http://www.postgresql.org/docs/8.0/static/functions-datetime.html#FUNCTIONS-DATETIME-EXTRACT |         # http://www.postgresql.org/docs/current/static/functions-datetime.html#FUNCTIONS-DATETIME-EXTRACT | ||||||
|         if lookup_type == 'week_day': |         if lookup_type == 'week_day': | ||||||
|             # For consistency across backends, we return Sunday=1, Saturday=7. |             # For consistency across backends, we return Sunday=1, Saturday=7. | ||||||
|             sql = "EXTRACT('dow' FROM %s) + 1" % field_name |             sql = "EXTRACT('dow' FROM %s) + 1" % field_name | ||||||
| @@ -57,7 +57,7 @@ class DatabaseOperations(BaseDatabaseOperations): | |||||||
|             params = [tzname] |             params = [tzname] | ||||||
|         else: |         else: | ||||||
|             params = [] |             params = [] | ||||||
|         # http://www.postgresql.org/docs/8.0/static/functions-datetime.html#FUNCTIONS-DATETIME-TRUNC |         # http://www.postgresql.org/docs/current/static/functions-datetime.html#FUNCTIONS-DATETIME-TRUNC | ||||||
|         sql = "DATE_TRUNC('%s', %s)" % (lookup_type, field_name) |         sql = "DATE_TRUNC('%s', %s)" % (lookup_type, field_name) | ||||||
|         return sql, params |         return sql, params | ||||||
|  |  | ||||||
| @@ -178,17 +178,6 @@ class DatabaseOperations(BaseDatabaseOperations): | |||||||
|     def prep_for_iexact_query(self, x): |     def prep_for_iexact_query(self, x): | ||||||
|         return x |         return x | ||||||
|  |  | ||||||
|     def check_aggregate_support(self, aggregate): |  | ||||||
|         """Check that the backend fully supports the provided aggregate. |  | ||||||
|  |  | ||||||
|         The implementation of population statistics (STDDEV_POP and VAR_POP) |  | ||||||
|         under Postgres 8.2 - 8.2.4 is known to be faulty. Raise |  | ||||||
|         NotImplementedError if this is the database in use. |  | ||||||
|         """ |  | ||||||
|         if aggregate.sql_function in ('STDDEV_POP', 'VAR_POP'): |  | ||||||
|             if 80200 <= self.connection.pg_version <= 80204: |  | ||||||
|                 raise NotImplementedError('PostgreSQL 8.2 to 8.2.4 is known to have a faulty implementation of %s. Please upgrade your version of PostgreSQL.' % aggregate.sql_function) |  | ||||||
|  |  | ||||||
|     def max_name_length(self): |     def max_name_length(self): | ||||||
|         """ |         """ | ||||||
|         Returns the maximum length of an identifier. |         Returns the maximum length of an identifier. | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ only the common types, such as ``VARCHAR`` and ``INTEGER``. For more obscure | |||||||
| column types, such as geographic polygons or even user-created types such as | column types, such as geographic polygons or even user-created types such as | ||||||
| `PostgreSQL custom types`_, you can define your own Django ``Field`` subclasses. | `PostgreSQL custom types`_, you can define your own Django ``Field`` subclasses. | ||||||
|  |  | ||||||
| .. _PostgreSQL custom types: http://www.postgresql.org/docs/8.2/interactive/sql-createtype.html | .. _PostgreSQL custom types: http://www.postgresql.org/docs/current/interactive/sql-createtype.html | ||||||
|  |  | ||||||
| Alternatively, you may have a complex Python object that can somehow be | Alternatively, you may have a complex Python object that can somehow be | ||||||
| serialized to fit into a standard database column type. This is another case | serialized to fit into a standard database column type. This is another case | ||||||
|   | |||||||
| @@ -3,13 +3,6 @@ | |||||||
| GEOGRAPHY=0 | GEOGRAPHY=0 | ||||||
| POSTGIS_SQL=postgis.sql | POSTGIS_SQL=postgis.sql | ||||||
|  |  | ||||||
| # For Ubuntu 8.x and 9.x releases. |  | ||||||
| if [ -d "/usr/share/postgresql-8.3-postgis" ] |  | ||||||
| then |  | ||||||
|     POSTGIS_SQL_PATH=/usr/share/postgresql-8.3-postgis |  | ||||||
|     POSTGIS_SQL=lwpostgis.sql |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| # For Ubuntu 10.04 | # For Ubuntu 10.04 | ||||||
| if [ -d "/usr/share/postgresql/8.4/contrib" ] | if [ -d "/usr/share/postgresql/8.4/contrib" ] | ||||||
| then | then | ||||||
|   | |||||||
| @@ -61,7 +61,7 @@ supported versions, and any notes for each of the supported database backends: | |||||||
| ==================  ==============================  ==================  ========================================= | ==================  ==============================  ==================  ========================================= | ||||||
| Database            Library Requirements            Supported Versions  Notes | Database            Library Requirements            Supported Versions  Notes | ||||||
| ==================  ==============================  ==================  ========================================= | ==================  ==============================  ==================  ========================================= | ||||||
| PostgreSQL          GEOS, PROJ.4, PostGIS           8.2+                Requires PostGIS. | PostgreSQL          GEOS, PROJ.4, PostGIS           8.4+                Requires PostGIS. | ||||||
| MySQL               GEOS                            5.x                 Not OGC-compliant; :ref:`limited functionality <mysql-spatial-limitations>`. | MySQL               GEOS                            5.x                 Not OGC-compliant; :ref:`limited functionality <mysql-spatial-limitations>`. | ||||||
| Oracle              GEOS                            10.2, 11            XE not supported; not tested with 9. | Oracle              GEOS                            10.2, 11            XE not supported; not tested with 9. | ||||||
| SQLite              GEOS, GDAL, PROJ.4, SpatiaLite  3.6.+               Requires SpatiaLite 2.3+, pysqlite2 2.5+ | SQLite              GEOS, GDAL, PROJ.4, SpatiaLite  3.6.+               Requires SpatiaLite 2.3+, pysqlite2 2.5+ | ||||||
|   | |||||||
| @@ -77,20 +77,7 @@ negating the effect of persistent connections. | |||||||
| PostgreSQL notes | PostgreSQL notes | ||||||
| ================ | ================ | ||||||
|  |  | ||||||
| Django supports PostgreSQL 8.2 and higher. | Django supports PostgreSQL 8.4 and higher. | ||||||
|  |  | ||||||
| PostgreSQL 8.2 to 8.2.4 |  | ||||||
| ----------------------- |  | ||||||
|  |  | ||||||
| The implementation of the population statistics aggregates ``STDDEV_POP`` and |  | ||||||
| ``VAR_POP`` that shipped with PostgreSQL 8.2 to 8.2.4 are `known to be |  | ||||||
| faulty`_. Users of these releases of PostgreSQL are advised to upgrade to |  | ||||||
| `Release 8.2.5`_ or later. Django will raise a ``NotImplementedError`` if you |  | ||||||
| attempt to use the ``StdDev(sample=False)`` or ``Variance(sample=False)`` |  | ||||||
| aggregate with a database backend that falls within the affected release range. |  | ||||||
|  |  | ||||||
| .. _known to be faulty: http://archives.postgresql.org/pgsql-bugs/2007-07/msg00046.php |  | ||||||
| .. _Release 8.2.5: http://www.postgresql.org/docs/devel/static/release-8-2-5.html |  | ||||||
|  |  | ||||||
| PostgreSQL connection settings | PostgreSQL connection settings | ||||||
| ------------------------------- | ------------------------------- | ||||||
| @@ -165,7 +152,7 @@ such as ``REPEATABLE READ`` or ``SERIALIZABLE``, set it in the | |||||||
|     handle exceptions raised on serialization failures. This option is |     handle exceptions raised on serialization failures. This option is | ||||||
|     designed for advanced uses. |     designed for advanced uses. | ||||||
|  |  | ||||||
| .. _postgresql-isolation-levels: http://www.postgresql.org/docs/devel/static/transaction-iso.html | .. _postgresql-isolation-levels: http://www.postgresql.org/docs/current/static/transaction-iso.html | ||||||
|  |  | ||||||
| Indexes for ``varchar`` and ``text`` columns | Indexes for ``varchar`` and ``text`` columns | ||||||
| -------------------------------------------- | -------------------------------------------- | ||||||
| @@ -179,7 +166,7 @@ for the column.  The extra index is necessary to correctly perform | |||||||
| lookups that use the ``LIKE`` operator in their SQL, as is done with the | lookups that use the ``LIKE`` operator in their SQL, as is done with the | ||||||
| ``contains`` and ``startswith`` lookup types. | ``contains`` and ``startswith`` lookup types. | ||||||
|  |  | ||||||
| .. _PostgreSQL operator class: http://www.postgresql.org/docs/8.4/static/indexes-opclass.html | .. _PostgreSQL operator class: http://www.postgresql.org/docs/current/static/indexes-opclass.html | ||||||
|  |  | ||||||
| .. _mysql-notes: | .. _mysql-notes: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -628,7 +628,7 @@ object. If it's ``None``, Django uses the :ref:`current time zone | |||||||
|     - MySQL: load the time zone tables with `mysql_tzinfo_to_sql`_. |     - MySQL: load the time zone tables with `mysql_tzinfo_to_sql`_. | ||||||
|  |  | ||||||
|     .. _pytz: http://pytz.sourceforge.net/ |     .. _pytz: http://pytz.sourceforge.net/ | ||||||
|     .. _Time Zones: http://www.postgresql.org/docs/9.2/static/datatype-datetime.html#DATATYPE-TIMEZONES |     .. _Time Zones: http://www.postgresql.org/docs/current/static/datatype-datetime.html#DATATYPE-TIMEZONES | ||||||
|     .. _Choosing a Time Zone File: http://docs.oracle.com/cd/B19306_01/server.102/b14225/ch4datetime.htm#i1006667 |     .. _Choosing a Time Zone File: http://docs.oracle.com/cd/B19306_01/server.102/b14225/ch4datetime.htm#i1006667 | ||||||
|     .. _mysql_tzinfo_to_sql: http://dev.mysql.com/doc/refman/5.5/en/mysql-tzinfo-to-sql.html |     .. _mysql_tzinfo_to_sql: http://dev.mysql.com/doc/refman/5.5/en/mysql-tzinfo-to-sql.html | ||||||
|  |  | ||||||
|   | |||||||
| @@ -557,7 +557,7 @@ backend-specific. | |||||||
| Supported for the PostgreSQL_ (``postgresql_psycopg2``) and MySQL_ (``mysql``) | Supported for the PostgreSQL_ (``postgresql_psycopg2``) and MySQL_ (``mysql``) | ||||||
| backends. | backends. | ||||||
|  |  | ||||||
| .. _PostgreSQL: http://www.postgresql.org/docs/8.2/static/multibyte.html | .. _PostgreSQL: http://www.postgresql.org/docs/current/static/multibyte.html | ||||||
| .. _MySQL: http://dev.mysql.com/doc/refman/5.0/en/charset-database.html | .. _MySQL: http://dev.mysql.com/doc/refman/5.0/en/charset-database.html | ||||||
|  |  | ||||||
| .. setting:: TEST_COLLATION | .. setting:: TEST_COLLATION | ||||||
|   | |||||||
| @@ -20,14 +20,14 @@ able to store certain characters in the database, and information will be lost. | |||||||
| * MySQL users, refer to the `MySQL manual`_ (section 9.1.3.2 for MySQL 5.1) | * MySQL users, refer to the `MySQL manual`_ (section 9.1.3.2 for MySQL 5.1) | ||||||
|   for details on how to set or alter the database character set encoding. |   for details on how to set or alter the database character set encoding. | ||||||
|  |  | ||||||
| * PostgreSQL users, refer to the `PostgreSQL manual`_ (section 21.2.2 in | * PostgreSQL users, refer to the `PostgreSQL manual`_ (section 22.3.2 in | ||||||
|   PostgreSQL 8) for details on creating databases with the correct encoding. |   PostgreSQL 9) for details on creating databases with the correct encoding. | ||||||
|  |  | ||||||
| * SQLite users, there is nothing you need to do. SQLite always uses UTF-8 | * SQLite users, there is nothing you need to do. SQLite always uses UTF-8 | ||||||
|   for internal encoding. |   for internal encoding. | ||||||
|  |  | ||||||
| .. _MySQL manual: http://dev.mysql.com/doc/refman/5.1/en/charset-database.html | .. _MySQL manual: http://dev.mysql.com/doc/refman/5.1/en/charset-database.html | ||||||
| .. _PostgreSQL manual: http://www.postgresql.org/docs/8.2/static/multibyte.html#AEN24104 | .. _PostgreSQL manual: http://www.postgresql.org/docs/current/static/multibyte.html | ||||||
|  |  | ||||||
| All of Django's database backends automatically convert Unicode strings into | All of Django's database backends automatically convert Unicode strings into | ||||||
| the appropriate encoding for talking to the database. They also automatically | the appropriate encoding for talking to the database. They also automatically | ||||||
|   | |||||||
| @@ -352,6 +352,17 @@ in an external repository`__. | |||||||
| __ https://disqus.com/ | __ https://disqus.com/ | ||||||
| __ https://github.com/django/django-contrib-comments | __ https://github.com/django/django-contrib-comments | ||||||
|  |  | ||||||
|  | Support for PostgreSQL versions older than 8.4 | ||||||
|  | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | The end of upstream support periods was reached in December 2011 for | ||||||
|  | PostgreSQL 8.2 and in February 2013 for 8.3. As a consequence, Django 1.6 sets | ||||||
|  | 8.4 as the minimum PostgreSQL version it officially supports. | ||||||
|  |  | ||||||
|  | You're strongly encouraged to use the most recent version of PostgreSQL | ||||||
|  | available, because of performance improvements and to take advantage of the | ||||||
|  | native streaming replication available in PostgreSQL 9.x. | ||||||
|  |  | ||||||
| Changes to :ttag:`cycle` and :ttag:`firstof` | Changes to :ttag:`cycle` and :ttag:`firstof` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -155,7 +155,7 @@ of people with their ages calculated by the database:: | |||||||
|     Jane is 42. |     Jane is 42. | ||||||
|     ... |     ... | ||||||
|  |  | ||||||
| __ http://www.postgresql.org/docs/8.4/static/functions-datetime.html | __ http://www.postgresql.org/docs/current/static/functions-datetime.html | ||||||
|  |  | ||||||
| Passing parameters into ``raw()`` | Passing parameters into ``raw()`` | ||||||
| --------------------------------- | --------------------------------- | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user