You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							90 lines
						
					
					
						
							2.2 KiB
						
					
					
				
			
		
		
	
	
							90 lines
						
					
					
						
							2.2 KiB
						
					
					
				# sybase/pyodbc.py
 | 
						|
# Copyright (C) 2005-2022 the SQLAlchemy authors and contributors
 | 
						|
# <see AUTHORS file>
 | 
						|
#
 | 
						|
# This module is part of SQLAlchemy and is released under
 | 
						|
# the MIT License: https://www.opensource.org/licenses/mit-license.php
 | 
						|
 | 
						|
"""
 | 
						|
.. dialect:: sybase+pyodbc
 | 
						|
    :name: PyODBC
 | 
						|
    :dbapi: pyodbc
 | 
						|
    :connectstring: sybase+pyodbc://<username>:<password>@<dsnname>[/<database>]
 | 
						|
    :url: https://pypi.org/project/pyodbc/
 | 
						|
 | 
						|
Unicode Support
 | 
						|
---------------
 | 
						|
 | 
						|
The pyodbc driver currently supports usage of these Sybase types with
 | 
						|
Unicode or multibyte strings::
 | 
						|
 | 
						|
    CHAR
 | 
						|
    NCHAR
 | 
						|
    NVARCHAR
 | 
						|
    TEXT
 | 
						|
    VARCHAR
 | 
						|
 | 
						|
Currently *not* supported are::
 | 
						|
 | 
						|
    UNICHAR
 | 
						|
    UNITEXT
 | 
						|
    UNIVARCHAR
 | 
						|
 | 
						|
"""  # noqa
 | 
						|
 | 
						|
import decimal
 | 
						|
 | 
						|
from sqlalchemy import processors
 | 
						|
from sqlalchemy import types as sqltypes
 | 
						|
from sqlalchemy.connectors.pyodbc import PyODBCConnector
 | 
						|
from sqlalchemy.dialects.sybase.base import SybaseDialect
 | 
						|
from sqlalchemy.dialects.sybase.base import SybaseExecutionContext
 | 
						|
 | 
						|
 | 
						|
class _SybNumeric_pyodbc(sqltypes.Numeric):
 | 
						|
    """Turns Decimals with adjusted() < -6 into floats.
 | 
						|
 | 
						|
    It's not yet known how to get decimals with many
 | 
						|
    significant digits or very large adjusted() into Sybase
 | 
						|
    via pyodbc.
 | 
						|
 | 
						|
    """
 | 
						|
 | 
						|
    def bind_processor(self, dialect):
 | 
						|
        super_process = super(_SybNumeric_pyodbc, self).bind_processor(dialect)
 | 
						|
 | 
						|
        def process(value):
 | 
						|
            if self.asdecimal and isinstance(value, decimal.Decimal):
 | 
						|
 | 
						|
                if value.adjusted() < -6:
 | 
						|
                    return processors.to_float(value)
 | 
						|
 | 
						|
            if super_process:
 | 
						|
                return super_process(value)
 | 
						|
            else:
 | 
						|
                return value
 | 
						|
 | 
						|
        return process
 | 
						|
 | 
						|
 | 
						|
class SybaseExecutionContext_pyodbc(SybaseExecutionContext):
 | 
						|
    def set_ddl_autocommit(self, connection, value):
 | 
						|
        if value:
 | 
						|
            connection.autocommit = True
 | 
						|
        else:
 | 
						|
            connection.autocommit = False
 | 
						|
 | 
						|
 | 
						|
class SybaseDialect_pyodbc(PyODBCConnector, SybaseDialect):
 | 
						|
    execution_ctx_cls = SybaseExecutionContext_pyodbc
 | 
						|
    supports_statement_cache = True
 | 
						|
 | 
						|
    colspecs = {sqltypes.Numeric: _SybNumeric_pyodbc}
 | 
						|
 | 
						|
    @classmethod
 | 
						|
    def dbapi(cls):
 | 
						|
        return PyODBCConnector.dbapi()
 | 
						|
 | 
						|
 | 
						|
dialect = SybaseDialect_pyodbc
 |