mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Reintroduced the changes from [3855] with more flexible handling of version
strings. Refs #2188, #2827. git-svn-id: http://code.djangoproject.com/svn/django/trunk@3872 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		
							
								
								
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							| @@ -119,6 +119,7 @@ answer newbie questions, and generally made Django that much better: | |||||||
|     Eric Moritz <http://eric.themoritzfamily.com/> |     Eric Moritz <http://eric.themoritzfamily.com/> | ||||||
|     Robin Munn <http://www.geekforgod.com/> |     Robin Munn <http://www.geekforgod.com/> | ||||||
|     Nebojša Dorđević |     Nebojša Dorđević | ||||||
|  |     Fraser Nevett <mail@nevett.org> | ||||||
|     Sam Newman <http://www.magpiebrain.com/> |     Sam Newman <http://www.magpiebrain.com/> | ||||||
|     Neal Norwitz <nnorwitz@google.com> |     Neal Norwitz <nnorwitz@google.com> | ||||||
|     oggie rob <oz.robharvey@gmail.com> |     oggie rob <oz.robharvey@gmail.com> | ||||||
|   | |||||||
| @@ -820,7 +820,8 @@ def get_validation_errors(outfile, app=None): | |||||||
|     validates all models of all installed apps. Writes errors, if any, to outfile. |     validates all models of all installed apps. Writes errors, if any, to outfile. | ||||||
|     Returns number of errors. |     Returns number of errors. | ||||||
|     """ |     """ | ||||||
|     from django.db import models |     from django.conf import settings | ||||||
|  |     from django.db import models, connection | ||||||
|     from django.db.models.loading import get_app_errors |     from django.db.models.loading import get_app_errors | ||||||
|     from django.db.models.fields.related import RelatedObject |     from django.db.models.fields.related import RelatedObject | ||||||
|  |  | ||||||
| @@ -862,6 +863,12 @@ def get_validation_errors(outfile, app=None): | |||||||
|             if f.db_index not in (None, True, False): |             if f.db_index not in (None, True, False): | ||||||
|                 e.add(opts, '"%s": "db_index" should be either None, True or False.' % f.name) |                 e.add(opts, '"%s": "db_index" should be either None, True or False.' % f.name) | ||||||
|  |  | ||||||
|  |             # Check that maxlength <= 255 if using older MySQL versions. | ||||||
|  |             if settings.DATABASE_ENGINE == 'mysql': | ||||||
|  |                 db_version = connection.get_server_version() | ||||||
|  |                 if db_version < (5, 0, 3) and isinstance(f, (models.CharField, models.CommaSeparatedIntegerField, models.SlugField)) and f.maxlength > 255: | ||||||
|  |                     e.add(opts, '"%s": %s cannot have a "maxlength" greater than 255 when you are using a version of MySQL prior to 5.0.3 (you are using %s).' % (f.name, f.__class__.__name__, '.'.join(str(n) for n in db_version[:3]))) | ||||||
|  |  | ||||||
|             # Check to see if the related field will clash with any |             # Check to see if the related field will clash with any | ||||||
|             # existing fields, m2m fields, m2m related objects or related objects |             # existing fields, m2m fields, m2m related objects or related objects | ||||||
|             if f.rel: |             if f.rel: | ||||||
|   | |||||||
| @@ -13,6 +13,7 @@ except ImportError, e: | |||||||
| from MySQLdb.converters import conversions | from MySQLdb.converters import conversions | ||||||
| from MySQLdb.constants import FIELD_TYPE | from MySQLdb.constants import FIELD_TYPE | ||||||
| import types | import types | ||||||
|  | import re | ||||||
|  |  | ||||||
| DatabaseError = Database.DatabaseError | DatabaseError = Database.DatabaseError | ||||||
|  |  | ||||||
| @@ -24,6 +25,12 @@ django_conversions.update({ | |||||||
|     FIELD_TYPE.TIME: util.typecast_time, |     FIELD_TYPE.TIME: util.typecast_time, | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | # This should match the numerical portion of the version numbers (we can treat | ||||||
|  | # versions like 5.0.24 and 5.0.24a as the same). Based on the list of version | ||||||
|  | # at http://dev.mysql.com/doc/refman/4.1/en/news.html and | ||||||
|  | # http://dev.mysql.com/doc/refman/5.0/en/news.html . | ||||||
|  | server_version_re = re.compile(r'(\d{1,2})\.(\d{1,2})\.(\d{1,2})') | ||||||
|  |  | ||||||
| # This is an extra debug layer over MySQL queries, to display warnings. | # This is an extra debug layer over MySQL queries, to display warnings. | ||||||
| # It's only used when DEBUG=True. | # It's only used when DEBUG=True. | ||||||
| class MysqlDebugWrapper: | class MysqlDebugWrapper: | ||||||
| @@ -61,6 +68,7 @@ class DatabaseWrapper(local): | |||||||
|     def __init__(self): |     def __init__(self): | ||||||
|         self.connection = None |         self.connection = None | ||||||
|         self.queries = [] |         self.queries = [] | ||||||
|  |         self.server_version = None | ||||||
|  |  | ||||||
|     def _valid_connection(self): |     def _valid_connection(self): | ||||||
|         if self.connection is not None: |         if self.connection is not None: | ||||||
| @@ -110,6 +118,16 @@ class DatabaseWrapper(local): | |||||||
|             self.connection.close() |             self.connection.close() | ||||||
|             self.connection = None |             self.connection = None | ||||||
|  |  | ||||||
|  |     def get_server_version(self): | ||||||
|  |         if not self.server_version: | ||||||
|  |             if not self._valid_connection(): | ||||||
|  |                 self.cursor() | ||||||
|  |             m = server_version_re.match(self.connection.get_server_info()) | ||||||
|  |             if not m: | ||||||
|  |                 raise Exception('Unable to determine MySQL version from version string %r' % self.connection.get_server_info()) | ||||||
|  |             self.server_version = m.groups() | ||||||
|  |         return self.server_version | ||||||
|  |  | ||||||
| supports_constraints = True | supports_constraints = True | ||||||
|  |  | ||||||
| def quote_name(name): | def quote_name(name): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user