mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Implemented QuerySet.datetimes on PostgreSQL.
This commit is contained in:
		| @@ -1,5 +1,6 @@ | |||||||
| from __future__ import unicode_literals | from __future__ import unicode_literals | ||||||
|  |  | ||||||
|  | from django.conf import settings | ||||||
| from django.db.backends import BaseDatabaseOperations | from django.db.backends import BaseDatabaseOperations | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -36,6 +37,22 @@ class DatabaseOperations(BaseDatabaseOperations): | |||||||
|         # http://www.postgresql.org/docs/8.0/static/functions-datetime.html#FUNCTIONS-DATETIME-TRUNC |         # http://www.postgresql.org/docs/8.0/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): | ||||||
|  |         if settings.USE_TZ: | ||||||
|  |             field_name = "%s AT TIME ZONE %%s" % field_name | ||||||
|  |         # http://www.postgresql.org/docs/8.0/static/functions-datetime.html#FUNCTIONS-DATETIME-EXTRACT | ||||||
|  |         if lookup_type == 'week_day': | ||||||
|  |             # For consistency across backends, we return Sunday=1, Saturday=7. | ||||||
|  |             return "EXTRACT('dow' FROM %s) + 1" % field_name | ||||||
|  |         else: | ||||||
|  |             return "EXTRACT('%s' FROM %s)" % (lookup_type, field_name) | ||||||
|  |  | ||||||
|  |     def datetime_trunc_sql(self, lookup_type, field_name): | ||||||
|  |         if settings.USE_TZ: | ||||||
|  |             field_name = "%s AT TIME ZONE %%s" % field_name | ||||||
|  |         # http://www.postgresql.org/docs/8.0/static/functions-datetime.html#FUNCTIONS-DATETIME-TRUNC | ||||||
|  |         return "DATE_TRUNC('%s', %s)" % (lookup_type, field_name) | ||||||
|  |  | ||||||
|     def deferrable_sql(self): |     def deferrable_sql(self): | ||||||
|         return " DEFERRABLE INITIALLY DEFERRED" |         return " DEFERRABLE INITIALLY DEFERRED" | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user