Current File : //kunden/lib64/python3.9/site-packages/MySQLdb/__pycache__/connections.cpython-39.opt-1.pyc
a

R�oa`,�@s�dZddlZddlmZmZddlmZmZmZm	Z	m
Z
mZmZm
Z
mZmZddddd	d
�Ze�d�Zdd
�ZGdd�dej�ZdS)a
This module implements connections for MySQLdb. Presently there is
only one class: Connection. Others are unlikely. However, you might
want to make your own subclasses. In most cases, you will probably
override Connection.default_cursor with a non-standard Cursor class.
�N�)�cursors�_mysql)
�Warning�Error�InterfaceError�	DataError�
DatabaseError�OperationalError�IntegrityError�
InternalError�NotSupportedError�ProgrammingError�utf8�cp1252�koi8_r�koi8_u)Zutf8mb4Zutf8mb3�latin1Zkoi8rZkoi8uz^(\d+)cCs t�|�}|rt|�d��SdS)z�Returns the leading numeric part of a string.

    >>> numeric_part("20-alpha")
    20
    >>> numeric_part("foo")
    >>> numeric_part("16b")
    16
    rN)�re_numeric_part�match�int�group)�s�m�r�9/usr/lib64/python3.9/site-packages/MySQLdb/connections.py�numeric_part#s

rcs�eZdZdZejZ�fdd�Zdd�Zdd�Z	dd	�Z
ddd�Zd
d�Zdd�Z
dd�Zdd�Zdd�Z�fdd�Zdd�Zdd�ZeZeZeZeZeZeZeZeZeZeZ�ZS)�
Connectionz MySQL Database Connection Objectcs`ddlm}m}ddlm}m}ddlm}|��}d|vrJ|�	d�|d<d|vr`|�	d�|d<d	|vrr|d	}	n|}	i}
|	�
�D]6\}}t|t�r�t|t
�r�|d
d
�|
|<q�||
|<q�|
|d	<|�	d|j�}
|�dd
�}|�	dd�}|�	dd
�}|�	dd�|_|�dd�}||jO}|�	dd�}|�r4||jO}||d<|�	dd�}t�j|i|��|
|_dd�|	�
�D�|_tdd�|���d�d
d�D��|_d|_|�s�|��}|�|�|�r�|�|�|�r|j|j |j!|j"|j#|j$|j%fD]}||j&|<�q�t'|j&|j(<||��d�fdd�	}||jt'<|j)|j*@|_+|j+�rV|d
u�rV|�,|�g|_-d
S) a�
        Create a connection to the database. It is strongly recommended
        that you only use keyword parameters. Consult the MySQL C API
        documentation for more information.

        :param str host:        host to connect
        :param str user:        user to connect as
        :param str password:    password to use
        :param str passwd:      alias of password (deprecated)
        :param str database:    database to use
        :param str db:          alias of database (deprecated)
        :param int port:        TCP/IP port to connect to
        :param str unix_socket: location of unix_socket to use
        :param dict conv:       conversion dictionary, see MySQLdb.converters
        :param int connect_timeout:
            number of seconds to wait before the connection attempt fails.

        :param bool compress:   if set, compression is enabled
        :param str named_pipe:  if set, a named pipe is used to connect (Windows only)
        :param str init_command:
            command which is run once the connection is created

        :param str read_default_file:
            file from which default client values are read

        :param str read_default_group:
            configuration group to use from the default file

        :param type cursorclass:
            class object, used to create cursors (keyword only)

        :param bool use_unicode:
            If True, text-like columns are returned as unicode objects
            using the connection's character set. Otherwise, text-like
            columns are returned as bytes. Unicode objects will always
            be encoded to the connection's character set regardless of
            this setting.
            Default to True.

        :param str charset:
            If supplied, the connection character set will be changed
            to this character set.

        :param str auth_plugin:
            If supplied, the connection default authentication plugin will be
            changed to this value. Example values:
            `mysql_native_password` or `caching_sha2_password`

        :param str sql_mode:
            If supplied, the session SQL mode will be changed to this
            setting.
            For more details and legal values, see the MySQL documentation.

        :param int client_flag:
            flags to use or 0 (see MySQL docs or constants/CLIENTS.py)

        :param bool multi_statements:
            If True, enable multi statements for clients >= 4.1.
            Defaults to True.

        :param str ssl_mode:
            specify the security settings for connection to the server;
            see the MySQL documentation for more details
            (mysql_option(), MYSQL_OPT_SSL_MODE).
            Only one of 'DISABLED', 'PREFERRED', 'REQUIRED',
            'VERIFY_CA', 'VERIFY_IDENTITY' can be specified.

        :param dict ssl:
            dictionary or mapping contains SSL connection parameters;
            see the MySQL documentation for more details
            (mysql_ssl_set()).  If this is set, and the client does not
            support SSL, NotSupportedError will be raised.

        :param bool local_infile:
            enables LOAD LOCAL INFILE; zero disables

        :param bool autocommit:
            If False (default), autocommit is disabled.
            If True, autocommit is enabled.
            If None, autocommit isn't set and server default is used.

        :param bool binary_prefix:
            If set, the '_binary' prefix will be used for raw byte query
            arguments (e.g. Binary). This is disabled by default.

        There are a number of undocumented, non-standard methods. See the
        documentation for the MySQL C API for some hints on what they do.
        r)�CLIENT�
FIELD_TYPE)�conversions�
_bytes_or_str)�proxy�dbZdatabase�passwd�password�convN�cursorclass�charset��use_unicodeT�sql_modeZ
binary_prefixF�client_flag�multi_statements�
autocommitcSs"i|]\}}t|�tur||�qSr)�typer)�.0�k�vrrr�
<dictcomp>��z'Connection.__init__.<locals>.<dictcomp>cSsg|]}t|��qSr)r)r0�nrrr�
<listcomp>�r4z'Connection.__init__.<locals>.<listcomp>�.��asciics��|��j��S�N)�string_literal�encode�encoding)�uZdummy�r#rr�unicode_literal�sz,Connection.__init__.<locals>.unicode_literal)N).ZMySQLdb.constantsrrZMySQLdb.convertersr r!�weakrefr"�copy�pop�items�
isinstancer�list�default_cursor�get�_binary_prefixZ
MULTI_RESULTSZMULTI_STATEMENTS�super�__init__r'�encoders�tupleZget_server_info�split�_server_versionr=Zcharacter_set_name�set_character_set�set_sql_mode�STRINGZ
VAR_STRINGZVARCHARZ	TINY_BLOBZMEDIUM_BLOBZ	LONG_BLOBZBLOBZ	converter�strZJSONZserver_capabilitiesZTRANSACTIONSZ_transactionalr.�messages)�self�args�kwargsrrr r!r"Zkwargs2r&Zconv2r1r2r'r(r*r+r,r-r.�tr@��	__class__r?rrK8sxY



�

�	


zConnection.__init__cCs|Sr:r�rUrrr�	__enter__�szConnection.__enter__cCs|��dSr:)�close)rU�exc_type�	exc_value�	tracebackrrr�__exit__�szConnection.__exit__cCs&t|�}|��|kr"tj�||�dSr:)�boolZget_autocommitr�
connectionr.)rUZonrrrr.�szConnection.autocommitNcCs|p|j|�S)z�
        Create a cursor on which queries may be performed. The
        optional cursorclass parameter is used to create the
        Cursor. By default, self.cursorclass=cursors.Cursor is
        used.
        )r')rUr'rrr�cursor�szConnection.cursorcCs$t|t�rt|�}tj�||�dSr:)rE�	bytearray�bytesrrc�query)rUrgrrrrg�s
zConnection.querycCs|�|�}|jrd|S|S)Ns_binary)r;rI)rU�bs�xrrr�_bytes_literals
zConnection._bytes_literalcCsdd�t|j|��S)Ns(%s)�,)�join�map�literal)rUrXrrr�_tuple_literalszConnection._tuple_literalcCs�t|t�r|�|�|j��}njt|t�r4|�|�}nTt|t�rJ|�|�}n>t|tt	f�rd|�
|�}n$|�||j�}t|t�r�|�|j�}|S)aIf o is a single object, returns an SQL literal as a string.
        If o is a non-string sequence, the items of the sequence are
        converted and returned as a sequence.

        Non-standard. For internal use; do not use this in your
        applications.
        )
rErSr;r<r=rerjrfrMrFro�escaperL)rU�orrrrrn
s



zConnection.literalcCs|�d�dS)ziExplicitly begin a connection.

        This method is not used when autocommit=False (default).
        sBEGINN)rgr[rrr�begin!szConnection.begincst��|�t�||�|_dS)z,Set the connection character set to charset.N)rJrP�_charset_to_encodingrHr=)rUr(rYrrrP(szConnection.set_character_setcCs,|jdkrtd��|�d|�|��dS)zNSet the connection sql_mode. See MySQL documentation for
        legal values.��rz!server is too old to set sql_modezSET SESSION sql_mode='%s'N)rOr
rg�store_result)rUr+rrrrQ-s
zConnection.set_sql_modecCs.|jdkrdS|�d�|��}|�d�}|S)z�Return detailed information about warnings as a
        sequence of tuples of (Level, Code, Message). This
        is only supported in MySQL-4.1 and up. If your server
        is an earlier version, an empty sequence is returned.rtrz
SHOW WARNINGSr)rOrgrvZ	fetch_row)rU�r�warningsrrr�
show_warnings5s


zConnection.show_warnings)N)�__name__�
__module__�__qualname__�__doc__rZCursorrGrKr\rar.rdrgrjrornrrrPrQryrrrr	rr
rrrr
�
__classcell__rrrYrr3s4/
	r)r}�rer)rr�_exceptionsrrrrr	r
rrr
rrs�compilerrrcrrrrr�<module>s0�