mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #28138 -- Used output type handler instead of numbersAsStrings on Oracle cursor.
Thanks Tim Graham for the review.
This commit is contained in:
		| @@ -385,11 +385,24 @@ class FormatStylePlaceholderCursor: | ||||
|  | ||||
|     def __init__(self, connection): | ||||
|         self.cursor = connection.cursor() | ||||
|         # Necessary to retrieve decimal values without rounding error. | ||||
|         self.cursor.numbersAsStrings = True | ||||
|         self.cursor.outputtypehandler = self._output_type_handler | ||||
|         # The default for cx_Oracle < 5.3 is 50. | ||||
|         self.cursor.arraysize = 100 | ||||
|  | ||||
|     @staticmethod | ||||
|     def _output_type_handler(cursor, name, defaultType, length, precision, scale): | ||||
|         """ | ||||
|         Called for each db column fetched from cursors. Return numbers as | ||||
|         strings so that decimal values don't have rounding error. | ||||
|         """ | ||||
|         if defaultType == Database.NUMBER: | ||||
|             return cursor.var( | ||||
|                 Database.STRING, | ||||
|                 size=255, | ||||
|                 arraysize=cursor.arraysize, | ||||
|                 outconverter=str, | ||||
|             ) | ||||
|  | ||||
|     def _format_params(self, params): | ||||
|         try: | ||||
|             return {k: OracleParam(v, self, True) for k, v in params.items()} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user