mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed ORA-01461 error when trying to store more than 4000 bytes in a TextField under Oracle
git-svn-id: http://code.djangoproject.com/svn/django/trunk@6905 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -455,6 +455,23 @@ class FormatStylePlaceholderCursor(Database.Cursor): | |||||||
|         else: |         else: | ||||||
|             return tuple([smart_str(p, self.charset, True) for p in params]) |             return tuple([smart_str(p, self.charset, True) for p in params]) | ||||||
|  |  | ||||||
|  |     def _guess_input_sizes(self, params_list): | ||||||
|  |         # Mark any string parameter greater than 4000 characters as an NCLOB. | ||||||
|  |         if isinstance(params_list[0], dict): | ||||||
|  |             sizes = {} | ||||||
|  |             iterators = [params.iteritems() for params in params_list] | ||||||
|  |         else: | ||||||
|  |             sizes = [None] * len(params_list[0]) | ||||||
|  |             iterators = [enumerate(params) for params in params_list] | ||||||
|  |         for iterator in iterators: | ||||||
|  |             for key, value in iterator: | ||||||
|  |                 if isinstance(value, basestring) and len(value) > 4000: | ||||||
|  |                     sizes[key] = Database.NCLOB | ||||||
|  |         if isinstance(sizes, dict): | ||||||
|  |             self.setinputsizes(**sizes) | ||||||
|  |         else: | ||||||
|  |             self.setinputsizes(*sizes) | ||||||
|  |  | ||||||
|     def execute(self, query, params=None): |     def execute(self, query, params=None): | ||||||
|         if params is None: |         if params is None: | ||||||
|             params = [] |             params = [] | ||||||
| @@ -468,6 +485,7 @@ class FormatStylePlaceholderCursor(Database.Cursor): | |||||||
|         if query.endswith(';') or query.endswith('/'): |         if query.endswith(';') or query.endswith('/'): | ||||||
|             query = query[:-1] |             query = query[:-1] | ||||||
|         query = smart_str(query, self.charset) % tuple(args) |         query = smart_str(query, self.charset) % tuple(args) | ||||||
|  |         self._guess_input_sizes([params]) | ||||||
|         return Database.Cursor.execute(self, query, params) |         return Database.Cursor.execute(self, query, params) | ||||||
|  |  | ||||||
|     def executemany(self, query, params=None): |     def executemany(self, query, params=None): | ||||||
| @@ -484,6 +502,7 @@ class FormatStylePlaceholderCursor(Database.Cursor): | |||||||
|             query = query[:-1] |             query = query[:-1] | ||||||
|         query = smart_str(query, self.charset) % tuple(args) |         query = smart_str(query, self.charset) % tuple(args) | ||||||
|         new_param_list = [self._format_params(i) for i in params] |         new_param_list = [self._format_params(i) for i in params] | ||||||
|  |         self._guess_input_sizes(new_param_list) | ||||||
|         return Database.Cursor.executemany(self, query, new_param_list) |         return Database.Cursor.executemany(self, query, new_param_list) | ||||||
|  |  | ||||||
|     def fetchone(self): |     def fetchone(self): | ||||||
|   | |||||||
| @@ -11,6 +11,7 @@ class Article(models.Model): | |||||||
|     pub_date = models.DateTimeField() |     pub_date = models.DateTimeField() | ||||||
|     status = models.IntegerField(blank=True, null=True, choices=CHOICES) |     status = models.IntegerField(blank=True, null=True, choices=CHOICES) | ||||||
|     misc_data = models.CharField(max_length=100, blank=True) |     misc_data = models.CharField(max_length=100, blank=True) | ||||||
|  |     article_text = models.TextField() | ||||||
|  |  | ||||||
|     class Meta: |     class Meta: | ||||||
|         ordering = ('pub_date','headline') |         ordering = ('pub_date','headline') | ||||||
| @@ -41,5 +42,14 @@ Empty strings should be returned as Unicode | |||||||
| >>> a2 = Article.objects.get(pk=a.id) | >>> a2 = Article.objects.get(pk=a.id) | ||||||
| >>> a2.misc_data | >>> a2.misc_data | ||||||
| u'' | u'' | ||||||
|  |  | ||||||
|  | # TextFields can hold more than 4000 characters (this was broken in Oracle). | ||||||
|  | >>> a3 = Article(headline="Really, really big", pub_date=datetime.now()) | ||||||
|  | >>> a3.article_text = "ABCDE" * 1000 | ||||||
|  | >>> a3.save() | ||||||
|  | >>> a4 = Article.objects.get(pk=a3.id) | ||||||
|  | >>> len(a4.article_text) | ||||||
|  | 5000 | ||||||
|  |  | ||||||
| """ | """ | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user