mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	The database cache wasn't correctly handling expired keys. Fixed now.
The cache tests have been failing for a long time with the db backend. This change makes them pass again, so no test changes required here. git-svn-id: http://code.djangoproject.com/svn/django/trunk@9942 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		
							
								
								
									
										9
									
								
								django/core/cache/backends/db.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								django/core/cache/backends/db.py
									
									
									
									
										vendored
									
									
								
							| @@ -54,9 +54,11 @@ class CacheClass(BaseCache): | |||||||
|         if num > self._max_entries: |         if num > self._max_entries: | ||||||
|             self._cull(cursor, now) |             self._cull(cursor, now) | ||||||
|         encoded = base64.encodestring(pickle.dumps(value, 2)).strip() |         encoded = base64.encodestring(pickle.dumps(value, 2)).strip() | ||||||
|         cursor.execute("SELECT cache_key FROM %s WHERE cache_key = %%s" % self._table, [key]) |         cursor.execute("SELECT cache_key, expires FROM %s WHERE cache_key = %%s" % self._table, [key]) | ||||||
|         try: |         try: | ||||||
|             if mode == 'set' and cursor.fetchone(): |             result = cursor.fetchone() | ||||||
|  |             if result and (mode == 'set' or | ||||||
|  |                     (mode == 'add' and result[1] < now)): | ||||||
|                 cursor.execute("UPDATE %s SET value = %%s, expires = %%s WHERE cache_key = %%s" % self._table, [encoded, str(exp), key]) |                 cursor.execute("UPDATE %s SET value = %%s, expires = %%s WHERE cache_key = %%s" % self._table, [encoded, str(exp), key]) | ||||||
|             else: |             else: | ||||||
|                 cursor.execute("INSERT INTO %s (cache_key, value, expires) VALUES (%%s, %%s, %%s)" % self._table, [key, encoded, str(exp)]) |                 cursor.execute("INSERT INTO %s (cache_key, value, expires) VALUES (%%s, %%s, %%s)" % self._table, [key, encoded, str(exp)]) | ||||||
| @@ -73,8 +75,9 @@ class CacheClass(BaseCache): | |||||||
|         transaction.commit_unless_managed() |         transaction.commit_unless_managed() | ||||||
|  |  | ||||||
|     def has_key(self, key): |     def has_key(self, key): | ||||||
|  |         now = datetime.now().replace(microsecond=0) | ||||||
|         cursor = connection.cursor() |         cursor = connection.cursor() | ||||||
|         cursor.execute("SELECT cache_key FROM %s WHERE cache_key = %%s" % self._table, [key]) |         cursor.execute("SELECT cache_key FROM %s WHERE cache_key = %%s and expires > %%s" % self._table, [key, now]) | ||||||
|         return cursor.fetchone() is not None |         return cursor.fetchone() is not None | ||||||
|  |  | ||||||
|     def _cull(self, cursor, now): |     def _cull(self, cursor, now): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user