3
gl                 @   s   d dl Z d dlZd dlmZ d dlmZ d dlmZmZ d dl	m
Z
 d dlmZmZ d dlmZmZmZ d dlmZ d d	lmZ d d
lmZ d dlmZmZ d dlmZ d dlmZ ddlm Z  ddl!m"Z"m#Z#m$Z$ G dd de
Z%dS )    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            
       s.  e Zd Zdddddddddd	ZejddiZdZd	Zd
ddedZdd Z	dd Z
dddZedZdd Zdd Zdd Zdd Zdd Zd d! Zdd"d#Z fd$d%Zd&d' Zd(d) Zd*d+ Zd,d- Zd.d/ Zd0d1 Zd2d3 Zed4d5 Zed6d7 Zd8d9 Z d:d; Z!d<d= Z"d>d? Z#d@dA Z$dBdC Z%dDdE Z&ddFdGZ'dHdI Z(dJdK Z)dLdM Z*dNdO Z+dPdQ Z,dRdS Z-dTdU Z.dVdW Z/dXdY Z0e1dZd[ Z2d\d\d]d^d_Z3d`da Z4dbdc Z5ddde Z6ddfdgZ7dhdi Z8djdk Z9dldm Z:ddndoZ; fdpdqZ<drds Z=dtdu Z>dvdw Z? fdxdyZ@dzd{ ZAd|d} ZB  ZCS )DatabaseOperations   g]    9V r   韆 )	ZSmallIntegerFieldZIntegerFieldZBigIntegerFieldZPositiveBigIntegerFieldZPositiveSmallIntegerFieldZ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;
/zNVARCHAR2(2000)z
NUMBER(11)z
NUMBER(19)z	NUMBER(5))r	   r   r   	TextFieldc             C   s   dS )NzSSELECT cache_key FROM %s ORDER BY cache_key OFFSET %%s ROWS FETCH FIRST 1 ROWS ONLY )selfr!   r!   b/var/www/tester-filtro-web/env/lib/python3.6/site-packages/django/db/backends/oracle/operations.pycache_key_culling_sqlH   s    z(DatabaseOperations.cache_key_culling_sqlc             C   sd   |dkrd| S |dkr d| S |dkr0d| S |dkr@d| S |d	krPd
| S d|j  |f S d S )NZweek_dayzTO_CHAR(%s, 'D')Ziso_week_dayzTO_CHAR(%s - 1, 'D')weekzTO_CHAR(%s, 'IW')quarterzTO_CHAR(%s, 'Q')Ziso_yearzTO_CHAR(%s, 'IYYY')zEXTRACT(%s FROM %s))upper)r"   lookup_type
field_namer!   r!   r#   date_extract_sqlK   s    z#DatabaseOperations.date_extract_sqlNc             C   sP   | j ||}|d	kr$d||j f S |dkr4d| S |dkrDd| S d| S d S )
NyearmonthzTRUNC(%s, '%s')r&   zTRUNC(%s, 'Q')r%   zTRUNC(%s, 'IW')z	TRUNC(%s))r+   r,   )_convert_field_to_tzr'   )r"   r(   r)   tznamer!   r!   r#   date_trunc_sql\   s    z!DatabaseOperations.date_trunc_sqlz^[\w/:+-]+$c             C   s8   d|kr||j dd  S d|kr4||j dd  S |S )N+-)find)r"   r.   r!   r!   r#   _prepare_tzname_deltan   s
    z(DatabaseOperations._prepare_tzname_deltac             C   sN   t jo|s|S | jj|s&td| | jj|krJd|| jj| j|f S |S )NzInvalid time zone name: %sz8CAST((FROM_TZ(%s, '%s') AT TIME ZONE '%s') AS TIMESTAMP))r   USE_TZ
_tzname_rematch
ValueError
connectionZtimezone_namer3   )r"   r)   r.   r!   r!   r#   r-   u   s    
z'DatabaseOperations._convert_field_to_tzc             C   s   | j ||}d| S )Nz	TRUNC(%s))r-   )r"   r)   r.   r!   r!   r#   datetime_cast_date_sql   s    z)DatabaseOperations.datetime_cast_date_sqlc             C   s   | j ||S )N)r-   )r"   r)   r.   r!   r!   r#   datetime_cast_time_sql   s    z)DatabaseOperations.datetime_cast_time_sqlc             C   s   | j ||}| j||S )N)r-   r*   )r"   r(   r)   r.   r!   r!   r#   datetime_extract_sql   s    z'DatabaseOperations.datetime_extract_sqlc             C   s   | j ||}|dkr&d||j f }nb|dkr8d| }nP|dkrJd| }n>|dkr\d	| }n,|d
krnd| }n|dkrd| }nd| }|S )Nr+   r,   zTRUNC(%s, '%s')r&   zTRUNC(%s, 'Q')r%   zTRUNC(%s, 'IW')dayz	TRUNC(%s)hourzTRUNC(%s, 'HH24')minutezTRUNC(%s, 'MI')zCAST(%s AS DATE))r+   r,   )r-   r'   )r"   r(   r)   r.   sqlr!   r!   r#   datetime_trunc_sql   s    




z%DatabaseOperations.datetime_trunc_sqlc             C   sD   | j ||}|dkrd| }n"|dkr0d| }n|dkr@d| }|S )Nr=   zTRUNC(%s, 'HH24')r>   zTRUNC(%s, 'MI')secondzCAST(%s AS DATE))r-   )r"   r(   r)   r.   r?   r!   r!   r#   time_trunc_sql   s    

z!DatabaseOperations.time_trunc_sqlc                s   t  j|}|jj }|d
kr,|j| j n|dkrB|j| j nr|dkrX|j| j n\|dkrttj	r|j| j
 n@|dkr|j| j n*|dkr|j| j n|d	kr|j| j |jjr|j|dkr| jn| j |S )N	JSONFieldr    ZBinaryFieldBooleanFieldNullBooleanFieldZDateTimeField	DateFieldZ	TimeFieldZ	UUIDField)rC   r    )rD   rE   )superget_db_convertersZoutput_fieldget_internal_typeappendconvert_textfield_valueconvert_binaryfield_valueconvert_booleanfield_valuer   r4   convert_datetimefield_valueconvert_datefield_valueconvert_timefield_valueconvert_uuidfield_valuefieldZempty_strings_allowedconvert_empty_bytesconvert_empty_string)r"   
expression
convertersinternal_type)	__class__r!   r#   rH      s,    
z$DatabaseOperations.get_db_convertersc             C   s   t |tjr|j }|S )N)
isinstancer   LOBread)r"   valuerU   r8   r!   r!   r#   rK      s    z*DatabaseOperations.convert_textfield_valuec             C   s   t |tjrt|j }|S )N)rY   r   rZ   r   r[   )r"   r\   rU   r8   r!   r!   r#   rL      s    z,DatabaseOperations.convert_binaryfield_valuec             C   s   |dkrt |}|S )Nr   r   )r   r   )bool)r"   r\   rU   r8   r!   r!   r#   rM      s    z-DatabaseOperations.convert_booleanfield_valuec             C   s   |d k	rt j|| jj }|S )N)r   Z
make_awarer8   )r"   r\   rU   r8   r!   r!   r#   rN      s    z.DatabaseOperations.convert_datetimefield_valuec             C   s   t |tjr|j }|S )N)rY   r   	Timestampdate)r"   r\   rU   r8   r!   r!   r#   rO      s    z*DatabaseOperations.convert_datefield_valuec             C   s   t |tjr|j }|S )N)rY   r   r^   time)r"   r\   rU   r8   r!   r!   r#   rP      s    z*DatabaseOperations.convert_timefield_valuec             C   s   |d k	rt j|}|S )N)uuidUUID)r"   r\   rU   r8   r!   r!   r#   rQ      s    
z*DatabaseOperations.convert_uuidfield_valuec             C   s   | d krdS | S )N r!   )r\   rU   r8   r!   r!   r#   rT      s    z'DatabaseOperations.convert_empty_stringc             C   s   | d krdS | S )N    r!   )r\   rU   r8   r!   r!   r#   rS      s    z&DatabaseOperations.convert_empty_bytesc             C   s   dS )Nz DEFERRABLE INITIALLY DEFERREDr!   )r"   r!   r!   r#   deferrable_sql   s    z!DatabaseOperations.deferrable_sqlc             C   sV   g }xH|D ]@}|j  }|d ks&|g kr.td|jt|trD|d n| q
W t|S )NzThe 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_valuer   rJ   rY   listtuple)r"   cursorZreturning_paramscolumnsparamr\   r!   r!   r#   fetch_returned_insert_columns  s    
 z0DatabaseOperations.fetch_returned_insert_columnsc             C   s"   |r|j dr|dkrdS dS d S )NrZ   rC   zDBMS_LOB.SUBSTR(%s)z%s)endswith)r"   Zdb_typerW   r!   r!   r#   field_cast_sql  s    z!DatabaseOperations.field_cast_sqlc             C   s   d S )Nr!   )r"   r!   r!   r#   no_limit_value  s    z!DatabaseOperations.no_limit_valuec             C   s@   | j ||\}}djdd |r&d| nd |r4d| nd fD S )N c             s   s   | ]}|r|V  qd S )Nr!   ).0r?   r!   r!   r#   	<genexpr>  s    z6DatabaseOperations.limit_offset_sql.<locals>.<genexpr>zOFFSET %d ROWSzFETCH FIRST %d ROWS ONLY)Z_get_limit_offset_paramsjoin)r"   Zlow_markZ	high_markfetchoffsetr!   r!   r#   limit_offset_sql  s    
z#DatabaseOperations.limit_offset_sqlc             C   s   |j }t|ttfrDxft|D ] \}}|jd| t|dd}qW n8t|tr|x,|j D ] \}}|jd| t|dd}qXW |S )Nz:arg%dreplace)errorsz:%s)		statementrY   rh   rg   	enumeraterw   r   dictitems)r"   ri   r?   paramsry   irk   keyr!   r!   r#   last_executed_query!  s    
z&DatabaseOperations.last_executed_queryc             C   s,   | j |t||}|jd|  |j d S )Nz"%s".currvalr   )_get_sequence_namer   executefetchone)r"   ri   
table_namepk_nameZsq_namer!   r!   r#   last_insert_id0  s    z!DatabaseOperations.last_insert_idc             C   s$   |d
krdS |dkr |dkr dS d	S )Niexact	icontainsistartswith	iendswithz	UPPER(%s)rC   exactzDBMS_LOB.SUBSTR(%s)z%s)r   r   r   r   r!   )r"   r(   rW   r!   r!   r#   lookup_cast5  s
    zDatabaseOperations.lookup_castc             C   s   dS )Ni  r!   )r"   r!   r!   r#   max_in_list_size<  s    z#DatabaseOperations.max_in_list_sizec             C   s   dS )N   r!   )r"   r!   r!   r#   max_name_length?  s    z"DatabaseOperations.max_name_lengthc             C   s   dS )NZNULLr!   )r"   r!   r!   r#   pk_default_valueB  s    z#DatabaseOperations.pk_default_valuec             C   s   |S )Nr!   )r"   xr!   r!   r#   prep_for_iexact_queryE  s    z(DatabaseOperations.prep_for_iexact_queryc             C   s   |d krdS |j  S )Nrc   )r[   )r"   r\   r!   r!   r#   process_clobH  s    zDatabaseOperations.process_clobc             C   sB   |j d r.|jd r.dt|j | j  }|jdd}|j S )N"z"%s"%z%%)
startswithrm   r   r'   r   rw   )r"   namer!   r!   r#   
quote_nameM  s    zDatabaseOperations.quote_namec             C   s   |dkrd}nd}d| S )Nregexz'c'z'i'zREGEXP_LIKE(%%s, %%s, %s)r!   )r"   r(   Zmatch_optionr!   r!   r#   regex_lookupZ  s    zDatabaseOperations.regex_lookupc             C   s   |sdf fS g }g }x@|D ]8}|j d| j|jjj| j|jf  |j t| qW ddj|djdgt| f t	|fS )Nrc   z%s.%szRETURNING %s INTO %sz, z%s)
rJ   r   model_metadb_tablecolumnr   rs   lenrh   )r"   fieldsfield_namesr}   rR   r!   r!   r#   return_insert_columnsa  s    
z(DatabaseOperations.return_insert_columnsc             C   sB   | j j .}|r"|jd||f n|jd|f |j S Q R X d S )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)
                )r8   ri   r   Zfetchall)r"   r   	recursiveri   r!   r!   r#   Z__foreign_key_constraintsq  s    
z,DatabaseOperations.__foreign_key_constraintsc             C   s   t dd| jS )Ni   )maxsize)r   ,_DatabaseOperations__foreign_key_constraints)r"   r!   r!   r#   _foreign_key_constraints  s    z+DatabaseOperations._foreign_key_constraintsF)reset_sequencesallow_cascadec               s   |sg S dd |D t  }xD|D ]<}x6 j||dD ]$\}}|rLj| |j||f q6W q"W  fdd|D  fddD   fdd|D  }	|r·fdd jjj D }
|	j j|
 |	S )	Nc             S   s   h | ]}|j  qS r!   )r'   )rq   tabler!   r!   r#   	<setcomp>  s    z/DatabaseOperations.sql_flush.<locals>.<setcomp>)r   c                sd   g | ]\\}}d j dj dj j|j dj dj j|j dj df qS )z%s %s %s %s %s %s %s %s;ALTERTABLEZDISABLE
CONSTRAINTZKEEPZINDEX)SQL_KEYWORD	SQL_FIELDr   )rq   r   
constraint)r"   styler!   r#   
<listcomp>  s   	z0DatabaseOperations.sql_flush.<locals>.<listcomp>c                s2   g | ]*}d j dj dj j|f qS )z	%s %s %s;ZTRUNCATEr   )r   r   r   )rq   r   )r"   r   r!   r#   r     s   c                sT   g | ]L\}}d j dj dj j|j dj dj j|f qS )z%s %s %s %s %s %s;r   r   ZENABLEr   )r   r   r   )rq   r   r   )r"   r   r!   r#   r     s   c                s    g | ]}|d  j   kr|qS )r   )r'   )rq   sequence)truncated_tablesr!   r#   r     s   )setr   addr8   ZintrospectionZsequence_listextendsequence_reset_by_name_sql)r"   r   Ztablesr   r   constraintsr   Zforeign_tabler   r?   	sequencesr!   )r"   r   r   r#   	sql_flush  s"    

&

zDatabaseOperations.sql_flushc       	      C   sl   g }xb|D ]Z}| j |d }| j|d }| j|d p8d}| j|||t|t|d }|j| q
W |S )Nr   r   id)no_autofield_sequence_namer   r   r   column_name)_get_no_autofield_sequence_namer   _sequence_reset_sqlr   rJ   )	r"   r   r   r?   Zsequence_infor   r   r   queryr!   r!   r#   r     s    
z-DatabaseOperations.sequence_reset_by_name_sqlc       
   
   C   s   g }| j }xt|D ]l}xf|jjD ]Z}t|tr| j|jj}| j|jj}| j|j}	|j	||||	t
|t
|	d  P qW qW |S )N)r   r   r   r   r   )r   r   Zlocal_fieldsrY   r	   r   r   r   r   rJ   r   )
r"   r   Z
model_listoutputr   r   fr   r   r   r!   r!   r#   sequence_reset_sql  s     


z%DatabaseOperations.sequence_reset_sqlc             C   s   dS )Nrc   r!   )r"   r!   r!   r#   start_transaction_sql  s    z(DatabaseOperations.start_transaction_sqlc             C   s$   |rd| j | S d| j | S d S )NzUSING INDEX TABLESPACE %szTABLESPACE %s)r   )r"   Z
tablespaceinliner!   r!   r#   tablespace_sql  s    z!DatabaseOperations.tablespace_sqlc             C   s   |S )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!   r#   adapt_datefield_value  s    z(DatabaseOperations.adapt_datefield_valuec             C   sN   |dkrdS t |dr|S tj|rDtjr<tj|| jj}ntdtj	|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_awarer   r4   Z
make_naiver8   r7   r   from_datetime)r"   r\   r!   r!   r#   adapt_datetimefield_value  s    


z,DatabaseOperations.adapt_datetimefield_valuec             C   s`   |d krd S t |dr|S t|tr2tjj|dS tj|rDtdtddd|j	|j
|j|jS )Nr   z%H:%M:%Sz5Oracle backend does not support timezone-aware times.il  r   )r   rY   strdatetimestrptimer   r   r7   r   r=   r>   rA   microsecond)r"   r\   r!   r!   r#   adapt_timefield_value  s    


z(DatabaseOperations.adapt_timefield_valuec             C   s   |S )Nr!   )r"   r\   Z
max_digitsZdecimal_placesr!   r!   r#   adapt_decimalfield_value0  s    z+DatabaseOperations.adapt_decimalfield_valuec                s   |\}}|dkrddj | S |dkr4ddj | S |dkrJd||d S |d	kr`d
||d S |dkrvd||d S |dkrddj | S |dkrtdt j||S )Nz%%zMOD(%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.)rs   r   rG   combine_expression)r"   Z	connectorZsub_expressionsr   r   )rX   r!   r#   r   3  s     z%DatabaseOperations.combine_expressionc             C   s"   | j  d }dtt||j  S )z
        Manually created sequence name to keep backward compatibility for
        AutoFields that aren't Oracle identity columns.
           z%s_SQ)r   r   r   r'   )r"   r   Zname_lengthr!   r!   r#   r   E  s    z2DatabaseOperations._get_no_autofield_sequence_namec             C   s2   |j d||g |j }|d kr*| j|S |d S )Nz
            SELECT sequence_name
            FROM user_tab_identity_cols
            WHERE table_name = UPPER(%s)
            AND column_name = UPPER(%s)r   )r   r   r   )r"   ri   r   r   rowr!   r!   r#   r   M  s    z%DatabaseOperations._get_sequence_namec       	      C   s   g }x|D ]~}g }x`t |D ]T\}}|| rVt|| d|| j }tjj|d| }|sfd||f }|j| qW |jddj|  q
W ddj| S )NZtarget_fieldz%sz	%s col_%szSELECT %s FROM DUALz, zSELECT * FROM (%s)z UNION ALL )rz   getattrrI   r   typesgetrJ   rs   )	r"   r   Zplaceholder_rowsr   r   selectr~   placeholderrW   r!   r!   r#   bulk_insert_sqlV  s    
z"DatabaseOperations.bulk_insert_sqlc       	         s@   |dkr0|\}}|\}}||}d||f |fS t  j|||S )NrF   z*NUMTODSINTERVAL(TO_NUMBER(%s - %s), 'DAY'))rG   subtract_temporals)	r"   rW   r   r   Zlhs_sqlZ
lhs_paramsZrhs_sqlZ
rhs_paramsr}   )rX   r!   r#   r   k  s    z%DatabaseOperations.subtract_temporalsc             C   s   |r| j jjt| S t|S )z5Oracle restricts the number of parameters in a query.)r8   featuresZmax_query_paramsr   )r"   r   objsr!   r!   r#   bulk_batch_sizes  s    z"DatabaseOperations.bulk_batch_sizec             C   sF   t |ttfrdS t |tr.|jr.| j|jS t |trB|jrBdS dS )z}
        Oracle supports only EXISTS(...) or filters in the WHERE clause, others
        must be compared with True.
        TF)rY   r
   r   r   Zconditional0conditional_expression_supported_in_where_clauserU   r   )r"   rU   r!   r!   r#   r   y  s    zCDatabaseOperations.conditional_expression_supported_in_where_clauseg] )r   r   g] )r   r   9V )r   r   )r   r   )r   r   )r   r   ay)r   r   g] )r   r   9V )r   r   )N)N)N)F)NN)D__name__
__module____qualname__Zinteger_field_rangesr   Zset_operatorsr   Z"cast_char_field_without_max_lengthZcast_data_typesr$   r*   r/   r   r5   r3   r-   r9   r:   r;   r@   rB   rH   rK   rL   rM   rN   rO   rP   rQ   staticmethodrT   rS   re   rl   rn   ro   rv   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   __classcell__r!   r!   )rX   r#   r      s   

	
!5
	
	r   )&r   ra   	functoolsr   Zdjango.confr   Z	django.dbr   r   Z"django.db.backends.base.operationsr   Zdjango.db.backends.utilsr   r   Zdjango.db.modelsr	   r
   r   Zdjango.db.models.expressionsr   Zdjango.db.models.sql.wherer   Zdjango.utilsr   Zdjango.utils.encodingr   r   Zdjango.utils.functionalr   Zdjango.utils.regex_helperr   baser   utilsr   r   r   r   r!   r!   r!   r#   <module>   s    