https://t.me/RX1948
Server : Apache
System : Linux iad1-shared-b8-43 6.6.49-grsec-jammy+ #10 SMP Thu Sep 12 23:23:08 UTC 2024 x86_64
User : dh_edsupp ( 6597262)
PHP Version : 8.2.26
Disable Function : NONE
Directory :  /lib/python3/dist-packages/django/db/backends/oracle/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //lib/python3/dist-packages/django/db/backends/oracle/__pycache__/operations.cpython-310.pyc
o

3�a�l�@s�ddlZddlZddlmZddlmZddlmZmZddl	m
Z
ddlmZm
Z
ddlmZmZmZddlmZdd	lmZdd
lmZddlmZmZddlmZdd
lmZddlm Z ddl!m"Z"m#Z#m$Z$Gdd�de
�Z%dS)�N)�	lru_cache)�settings)�
DatabaseError�NotSupportedError)�BaseDatabaseOperations)�strip_quotes�
truncate_name)�	AutoField�Exists�ExpressionWrapper)�RawSQL)�	WhereNode)�timezone)�force_bytes�	force_str)�cached_property)�_lazy_re_compile�)�Database)�BulkInsertMapper�	InsertVar�Oracle_datetimec
s2eZdZdddddddddd�	Ziej�ddi�Zd	Zd
Zddd
ed�Zdd�Z	dd�Z
ddd�Zed�Z
dd�Zdd�Zdd�Zdd�Zdd �Zd!d"�Zdd#d$�Z�fd%d&�Zd'd(�Zd)d*�Zd+d,�Zd-d.�Zd/d0�Zd1d2�Zd3d4�Zed5d6��Zed7d8��Zd9d:�Z d;d<�Z!d=d>�Z"d?d@�Z#dAdB�Z$dCdD�Z%dEdF�Z&ddGdH�Z'dIdJ�Z(dKdL�Z)dMdN�Z*dOdP�Z+dQdR�Z,dSdT�Z-dUdV�Z.dWdX�Z/dYdZ�Z0e1d[d\��Z2d]d]d^�d_d`�Z3dadb�Z4dcdd�Z5dedf�Z6d�dgdh�Z7didj�Z8dkdl�Z9dmdn�Z:d�dodp�Z;�fdqdr�Z<dsdt�Z=dudv�Z>dwdx�Z?�fdydz�Z@d{d|�ZAd}d~�ZB�ZCS)��DatabaseOperations)l�����g�]��g�])l������9V���9V)rr)rr)iay��i��)	�SmallIntegerField�IntegerField�BigIntegerField�PositiveBigIntegerField�PositiveSmallIntegerField�PositiveIntegerField�SmallAutoFieldr	�BigAutoField�
difference�MINUSa�
DECLARE
    table_value integer;
    seq_value integer;
    seq_name user_tab_identity_cols.sequence_name%%TYPE;
BEGIN
    BEGIN
        SELECT sequence_name INTO seq_name FROM user_tab_identity_cols
        WHERE  table_name = '%(table_name)s' AND
               column_name = '%(column_name)s';
        EXCEPTION WHEN NO_DATA_FOUND THEN
            seq_name := '%(no_autofield_sequence_name)s';
    END;

    SELECT NVL(MAX(%(column)s), 0) INTO table_value FROM %(table)s;
    SELECT NVL(last_number - cache_size, 0) INTO seq_value FROM user_sequences
           WHERE sequence_name = seq_name;
    WHILE table_value > seq_value LOOP
        EXECUTE IMMEDIATE 'SELECT "'||seq_name||'".nextval FROM DUAL'
        INTO seq_value;
    END LOOP;
END;
/zNVARCHAR2(2000)z
NUMBER(11)z
NUMBER(19)z	NUMBER(5))r	r"r!�	TextFieldcC�dS)NzSSELECT cache_key FROM %s ORDER BY cache_key OFFSET %%s ROWS FETCH FIRST 1 ROWS ONLY���selfr'r'�F/usr/lib/python3/dist-packages/django/db/backends/oracle/operations.py�cache_key_culling_sqlH�z(DatabaseOperations.cache_key_culling_sqlcCs`|dkrd|S|dkrd|S|dkrd|S|dkr d|S|d	kr(d
|Sd|��|fS)N�week_dayzTO_CHAR(%s, 'D')�iso_week_dayzTO_CHAR(%s - 1, 'D')�weekzTO_CHAR(%s, 'IW')�quarterzTO_CHAR(%s, 'Q')�iso_yearzTO_CHAR(%s, 'IYYY')zEXTRACT(%s FROM %s)��upper)r)�lookup_type�
field_namer'r'r*�date_extract_sqlKsz#DatabaseOperations.date_extract_sqlNcCsL|�||�}|dvrd||��fS|dkrd|S|dkr"d|Sd|S)N��year�month�TRUNC(%s, '%s')r0�TRUNC(%s, 'Q')r/�TRUNC(%s, 'IW')�	TRUNC(%s)��_convert_field_to_tzr3�r)r4r5�tznamer'r'r*�date_trunc_sql\sz!DatabaseOperations.date_trunc_sqlz^[\w/:+-]+$cCs8d|vr
||�d�d�Sd|vr||�d�d�S|S)N�+�-)�find)r)rAr'r'r*�_prepare_tzname_deltans
z(DatabaseOperations._prepare_tzname_deltacCsNtjr|s|S|j�|�std|��|jj|kr%d||jj|�|�fS|S)NzInvalid time zone name: %sz8CAST((FROM_TZ(%s, '%s') AT TIME ZONE '%s') AS TIMESTAMP))r�USE_TZ�
_tzname_re�match�
ValueError�
connection�
timezone_namerF�r)r5rAr'r'r*r?us
�z'DatabaseOperations._convert_field_to_tzcCs|�||�}d|S)Nr=�r?rMr'r'r*�datetime_cast_date_sql�sz)DatabaseOperations.datetime_cast_date_sqlcCs|�||�S�NrNrMr'r'r*�datetime_cast_time_sql�sz)DatabaseOperations.datetime_cast_time_sqlcCs|�||�}|�||�SrP)r?r6r@r'r'r*�datetime_extract_sql�sz'DatabaseOperations.datetime_extract_sqlcCs�|�||�}|dvrd||��f}|S|dkrd|}|S|dkr(d|}|S|dkr2d|}|S|d	kr<d
|}|S|dkrFd|}|Sd
|}|S)Nr7r:r0r;r/r<�dayr=�hour�TRUNC(%s, 'HH24')�minute�TRUNC(%s, 'MI')�CAST(%s AS DATE)r>�r)r4r5rA�sqlr'r'r*�datetime_trunc_sql�s*
��	����z%DatabaseOperations.datetime_trunc_sqlcCsH|�||�}|dkrd|}|S|dkrd|}|S|dkr"d|}|S)NrTrUrVrW�secondrXrNrYr'r'r*�time_trunc_sql�s��z!DatabaseOperations.time_trunc_sqlcs�t��|�}|j��}|dvr|�|j�nD|dkr!|�|j�n9|dvr,|�|j�n.|dkr:tj	r9|�|j
�n |dkrE|�|j�n|dkrP|�|j�n
|dkrZ|�|j
�|jjrk|�|dkrg|jn|j�|S)N)�	JSONFieldr%�BinaryField)�BooleanField�NullBooleanField�
DateTimeField�	DateField�	TimeField�	UUIDField)�super�get_db_converters�output_field�get_internal_type�append�convert_textfield_value�convert_binaryfield_value�convert_booleanfield_valuerrG�convert_datetimefield_value�convert_datefield_value�convert_timefield_value�convert_uuidfield_value�field�empty_strings_allowed�convert_empty_bytes�convert_empty_string)r)�
expression�
converters�
internal_type��	__class__r'r*rg�s2
���z$DatabaseOperations.get_db_converterscC�t|tj�r
|��}|SrP)�
isinstancer�LOB�read�r)�valuervrKr'r'r*rk��z*DatabaseOperations.convert_textfield_valuecCst|tj�rt|���}|SrP)r|rr}rr~rr'r'r*rl�sz,DatabaseOperations.convert_binaryfield_valuecCs|dvrt|�}|S)N)rr)�boolrr'r'r*rm�sz-DatabaseOperations.convert_booleanfield_valuecCs|durt�||jj�}|SrP)r�
make_awarerKrr'r'r*rn�sz.DatabaseOperations.convert_datetimefield_valuecCr{rP)r|r�	Timestamp�daterr'r'r*ro�r�z*DatabaseOperations.convert_datefield_valuecCr{rP)r|rr��timerr'r'r*rp�r�z*DatabaseOperations.convert_timefield_valuecCs|dur	t�|�}|SrP)�uuid�UUIDrr'r'r*rq�s
z*DatabaseOperations.convert_uuidfield_valuecC�|durdS|S�N�r'�r�rvrKr'r'r*ru��z'DatabaseOperations.convert_empty_stringcCr�)N�r'r�r'r'r*rt�r�z&DatabaseOperations.convert_empty_bytescCr&)Nz DEFERRABLE INITIALLY DEFERREDr'r(r'r'r*�deferrable_sql�r,z!DatabaseOperations.deferrable_sqlcCsRg}|D] }|��}|dus|gkrtd��|�t|t�r!|dn|�qt|�S)Nz�The database did not return a new row id. Probably "ORA-1403: no data found" was raised internally but was hidden by the Oracle OCI library (see https://code.djangoproject.com/ticket/28859).r)�	get_valuerrjr|�list�tuple)r)�cursor�returning_params�columns�paramr�r'r'r*�fetch_returned_insert_columnss�z0DatabaseOperations.fetch_returned_insert_columnscCs|r
|�d�r
|dkr
dSdS)Nr}r^�DBMS_LOB.SUBSTR(%s)�%s)�endswith)r)�db_typerxr'r'r*�field_cast_sqlsz!DatabaseOperations.field_cast_sqlcCsdSrPr'r(r'r'r*�no_limit_valuer,z!DatabaseOperations.no_limit_valuecCs@|�||�\}}d�dd�|rd|nd|rd|ndfD��S)N� css�|]}|r|VqdSrPr')�.0rZr'r'r*�	<genexpr>s��z6DatabaseOperations.limit_offset_sql.<locals>.<genexpr>zOFFSET %d ROWSzFETCH FIRST %d ROWS ONLY)�_get_limit_offset_params�join)r)�low_mark�	high_mark�fetch�offsetr'r'r*�limit_offset_sqls


�z#DatabaseOperations.limit_offset_sqlcCsz|j}t|ttf�r!t|�D]\}}|�d|t|dd��}q|St|t�r;|��D]\}}|�d|t|dd��}q*|S)Nz:arg%d�replace)�errorsz:%s)	�	statementr|r�r��	enumerater�r�dict�items)r)r�rZ�paramsr��ir��keyr'r'r*�last_executed_query!s
�z&DatabaseOperations.last_executed_querycCs,|�|t|�|�}|�d|�|��dS)Nz"%s".currvalr)�_get_sequence_namer�execute�fetchone)r)r��
table_name�pk_name�sq_namer'r'r*�last_insert_id0sz!DatabaseOperations.last_insert_idcCs$|dvrdS|dkr|dkrdSdS)N)�iexact�	icontains�istartswith�	iendswithz	UPPER(%s)r^�exactr�r�r')r)r4rxr'r'r*�lookup_cast5s
zDatabaseOperations.lookup_castcCr&)Ni�r'r(r'r'r*�max_in_list_size<r,z#DatabaseOperations.max_in_list_sizecCr&)N�r'r(r'r'r*�max_name_length?r,z"DatabaseOperations.max_name_lengthcCr&)N�NULLr'r(r'r'r*�pk_default_valueBr,z#DatabaseOperations.pk_default_valuecC�|SrPr')r)�xr'r'r*�prep_for_iexact_queryEr,z(DatabaseOperations.prep_for_iexact_querycCs|durdS|��Sr�)r~�r)r�r'r'r*�process_clobHszDatabaseOperations.process_clobcCs>|�d�s|�d�sdt|��|���}|�dd�}|��S)N�"z"%s"�%�%%)�
startswithr�rr3r�r�)r)�namer'r'r*�
quote_nameMszDatabaseOperations.quote_namecCs |dkr
d}d|Sd}d|S)N�regexz'c'z'i'zREGEXP_LIKE(%%s, %%s, %s)r')r)r4�match_optionr'r'r*�regex_lookupZs
�zDatabaseOperations.regex_lookupcCsx|sdSg}g}|D]}|�d|�|jjj�|�|j�f�|�t|��q
dd�|�d�dgt|��ft	|�fS)N)r�r'z%s.%szRETURNING %s INTO %s�, r�)
rjr��model�_meta�db_table�columnrr��lenr�)r)�fields�field_namesr�rrr'r'r*�return_insert_columnsas 
���z(DatabaseOperations.return_insert_columnscCsZ|j���}|r|�d||f�n|�d|f�|��Wd�S1s&wYdS)Na�
                    SELECT
                        user_tables.table_name, rcons.constraint_name
                    FROM
                        user_tables
                    JOIN
                        user_constraints cons
                        ON (user_tables.table_name = cons.table_name AND cons.constraint_type = ANY('P', 'U'))
                    LEFT JOIN
                        user_constraints rcons
                        ON (user_tables.table_name = rcons.table_name AND rcons.constraint_type = 'R')
                    START WITH user_tables.table_name = UPPER(%s)
                    CONNECT BY NOCYCLE PRIOR cons.constraint_name = rcons.r_constraint_name
                    GROUP BY
                        user_tables.table_name, rcons.constraint_name
                    HAVING user_tables.table_name != UPPER(%s)
                    ORDER BY MAX(level) DESC
                a6
                    SELECT
                        cons.table_name, cons.constraint_name
                    FROM
                        user_constraints cons
                    WHERE
                        cons.constraint_type = 'R'
                        AND cons.table_name = UPPER(%s)
                )rKr�r��fetchall)r)r��	recursiver�r'r'r*�__foreign_key_constraintsqs��	$�z,DatabaseOperations.__foreign_key_constraintscCstdd�|j�S)Ni)�maxsize)r�,_DatabaseOperations__foreign_key_constraintsr(r'r'r*�_foreign_key_constraints�sz+DatabaseOperations._foreign_key_constraintsF)�reset_sequences�
allow_cascadecs�|sgSdd�|D��t�}|D]}�j||d�D]\}}|r$��|�|�||f�qq��fdd�|D���fdd��D���fdd�|D�}	|rc�fdd��jj��D�}
|	����|
��|	S)	NcSsh|]}|���qSr'r2�r��tabler'r'r*�	<setcomp>�sz/DatabaseOperations.sql_flush.<locals>.<setcomp>)r�c
sdg|].\}}d��d���d�����|����d���d�����|����d���d�f�qS)z%s %s %s %s %s %s %s %s;�ALTER�TABLE�DISABLE�
CONSTRAINT�KEEP�INDEX��SQL_KEYWORD�	SQL_FIELDr��r�r��
constraint�r)�styler'r*�
<listcomp>�s
���z0DatabaseOperations.sql_flush.<locals>.<listcomp>c
s2g|]}d��d���d�����|��f�qS)z	%s %s %s;�TRUNCATEr�r�r�r�r'r*r��s���c
sTg|]&\}}d��d���d�����|����d���d�����|��f�qS)z%s %s %s %s %s %s;r�r��ENABLEr�r�r�r�r'r*r��s���cs g|]}|d���vr|�qS)r�r2)r��sequence)�truncated_tablesr'r*r��s
�)�setr��addrK�
introspection�
sequence_list�extend�sequence_reset_by_name_sql)r)r��tablesr�r��constraintsr��
foreign_tabler�rZ�	sequencesr')r)r�r�r*�	sql_flush�s6
�
�����

�zDatabaseOperations.sql_flushc	Cshg}|D]-}|�|d�}|�|d�}|�|dpd�}|j|||t|�t|�d�}|�|�q|S)Nr�r��id��no_autofield_sequence_namer�r�r��column_name)�_get_no_autofield_sequence_namer��_sequence_reset_sqlrrj)	r)r�rrZ�
sequence_inforr�r��queryr'r'r*r��s�z-DatabaseOperations.sequence_reset_by_name_sqlc
Cs~g}|j}|D]5}|jjD].}t|t�r;|�|jj�}|�|jj�}|�|j�}	|�	||||	t
|�t
|	�d��nq
q|S)Nr)rr��local_fieldsr|r	rr�r�r�rjr)
r)r��
model_list�outputr
r��frr�r�r'r'r*�sequence_reset_sql�s&

�	��z%DatabaseOperations.sequence_reset_sqlcCr&r�r'r(r'r'r*�start_transaction_sql�r,z(DatabaseOperations.start_transaction_sqlcCs |r	d|�|�Sd|�|�S)NzUSING INDEX TABLESPACE %sz
TABLESPACE %s)r�)r)�
tablespace�inliner'r'r*�tablespace_sql�sz!DatabaseOperations.tablespace_sqlcCr�)z�
        Transform a date value to an object compatible with what is expected
        by the backend driver for date columns.
        The default implementation transforms the date to text, but that is not
        necessary for Oracle.
        r'r�r'r'r*�adapt_datefield_value�sz(DatabaseOperations.adapt_datefield_valuecCsN|durdSt|d�r
|St�|�r"tjrt�||jj�}ntd��t�	|�S)aE
        Transform a datetime value to an object compatible with what is expected
        by the backend driver for datetime columns.

        If naive datetime is passed assumes that is in UTC. Normally Django
        models.DateTimeField makes sure that if USE_TZ is True passed datetime
        is timezone aware.
        N�resolve_expressionzNOracle backend does not support timezone-aware datetimes when USE_TZ is False.)
�hasattrr�is_awarerrG�
make_naiverKrJr�
from_datetimer�r'r'r*�adapt_datetimefield_values



z,DatabaseOperations.adapt_datetimefield_valuecCs`|durdSt|d�r
|St|t�rtj�|d�St�|�r"td��tddd|j	|j
|j|j�S)Nrz%H:%M:%Sz5Oracle backend does not support timezone-aware times.ilr)
rr|�str�datetime�strptimerrrJrrTrVr\�microsecondr�r'r'r*�adapt_timefield_values


�z(DatabaseOperations.adapt_timefield_valuecCr�rPr')r)r��
max_digits�decimal_placesr'r'r*�adapt_decimalfield_value0r,z+DatabaseOperations.adapt_decimalfield_valuecs�|\}}|dkrdd�|�S|dkrdd�|�S|dkr%d||d�S|d	kr0d
||d�S|dkr;d||d�S|d
krFdd�|�S|dkrNtd��t��||�S)Nr�zMOD(%s)�,�&z
BITAND(%s)�|z"BITAND(-%(lhs)s-1,%(rhs)s)+%(lhs)s)�lhs�rhsz<<z(%(lhs)s * POWER(2, %(rhs)s))z>>z"FLOOR(%(lhs)s / POWER(2, %(rhs)s))�^z	POWER(%s)�#z'Bitwise XOR is not supported in Oracle.)r�rrf�combine_expression)r)�	connector�sub_expressionsr&r'ryr'r*r*3s z%DatabaseOperations.combine_expressioncCs"|��d}dtt|�|���S)z�
        Manually created sequence name to keep backward compatibility for
        AutoFields that aren't Oracle identity columns.
        �z%s_SQ)r�rrr3)r)r��name_lengthr'r'r*rEsz2DatabaseOperations._get_no_autofield_sequence_namecCs2|�d||g�|��}|dur|�|�S|dS)Nz�
            SELECT sequence_name
            FROM user_tab_identity_cols
            WHERE table_name = UPPER(%s)
            AND column_name = UPPER(%s)r)r�r�r)r)r�r�r��rowr'r'r*r�Ms
�z%DatabaseOperations._get_sequence_namec	Cs�g}|D]=}g}t|�D]*\}}||r)t||d||���}tj�|d�|}|s1d||f}|�|�q|�dd�|��qdd�|�S)N�target_fieldr�z	%s col_%szSELECT %s FROM DUALr�zSELECT * FROM (%s)z UNION ALL )r��getattrrir�types�getrjr�)	r)r��placeholder_rowsr
r/�selectr��placeholderrxr'r'r*�bulk_insert_sqlVsz"DatabaseOperations.bulk_insert_sqlc	sF|dkr|\}}|\}}g|�|�R}d||f|fSt��|||�S)Nrcz*NUMTODSINTERVAL(TO_NUMBER(%s - %s), 'DAY'))rf�subtract_temporals)	r)rxr&r'�lhs_sql�
lhs_params�rhs_sql�
rhs_paramsr�ryr'r*r8ksz%DatabaseOperations.subtract_temporalscCs|r|jjjt|�St|�S)z5Oracle restricts the number of parameters in a query.)rK�features�max_query_paramsr�)r)r��objsr'r'r*�bulk_batch_sizessz"DatabaseOperations.bulk_batch_sizecCsFt|ttf�r	dSt|t�r|jr|�|j�St|t�r!|jr!dSdS)z}
        Oracle supports only EXISTS(...) or filters in the WHERE clause, others
        must be compared with True.
        TF)r|r
r
r�conditional�0conditional_expression_supported_in_where_clauservr)r)rvr'r'r*rByszCDatabaseOperations.conditional_expression_supported_in_where_clauserP)F)NN)D�__name__�
__module__�__qualname__�integer_field_rangesr�
set_operatorsr�"cast_char_field_without_max_length�cast_data_typesr+r6rBrrHrFr?rOrQrRr[r]rgrkrlrmrnrorprq�staticmethodrurtr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�rr�rr�rrrrrrr"r*rr�r7r8r@rB�
__classcell__r'r'ryr*rs���


	



!
5
	
	r)&rr��	functoolsr�django.confr�	django.dbrr�"django.db.backends.base.operationsr�django.db.backends.utilsrr�django.db.modelsr	r
r�django.db.models.expressionsr�django.db.models.sql.wherer
�django.utilsr�django.utils.encodingrr�django.utils.functionalr�django.utils.regex_helperr�baser�utilsrrrrr'r'r'r*�<module>s"

https://t.me/RX1948 - 2025