
    j[                    \   U d dl mZ d dlZd dlmZmZ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 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 d dl m!Z! d dl"m#Z#  ej$        e%          5  d dl&m'Z' ddd           n# 1 swxY w Y   erkd dl(Z(d dl)m*Z*m+Z+m,Z, d dl-m.Z. d dlm/Z/m0Z0m1Z1m2Z2 e(j3        dk    rd dlm4Z4 nd dl5m4Z4 ee!z  e#z  ej        z  ej#        e/         z  ej6        z  ej7        z  Z8de9d<   dgZ:d*dZ;d+d Z<ddd!d,d(Z= G d) dee                   Z>dS )-    )annotationsN)TYPE_CHECKINGGenericoverload)_check_for_pandas_check_for_pyarrow)pandas)pyarrow)	FrameType)deprecate_renamed_parameter)is_pycapsule)issue_unstable_warning)_get_stack_localsqualified_type_name)wrap_ldf)
from_arrowfrom_pandas)	DataFrame)	LazyFrame)Series)PySQLContext)Callable
CollectionMapping)TracebackType)AnyFinalLiteral	TypeAlias)      )Selfr   CompatibleFrameType
SQLContextobjr   returnboolc                   t          |           p~t          | t                    pit          |           o%t          | t          j        t          j        f          p4t          |           o%t          | t          j	        t          j
        f          S )z2Check if the object can be converted to DataFrame.)r   
isinstancer   r   pdr   r   r   paTableRecordBatch)r%   s    W/home/longshao/multi-rider-rag/.venv/lib/python3.11/site-packages/polars/sql/context.py_compatible_framer/   3   s{     	S 	Uc9%%	Uc""Qz#bi7P'Q'Q	U s##S
32>8R(S(S	    r   c                   t          | t          t          f          r|                                 S t          | t                    r&|                                                                 S t          |           rrt          | t          j        t          j        f          rLt          t          |           x}t                    r|                                }|                                S t          |           s5t          |           rGt          | t          j        t          j        f          r!t          |                                           S dt          |            }t!          |          )z'Return LazyFrame from compatible input.zunrecognised frame type: )r)   r   r   lazyr   to_framer   r*   r   r   r   r+   r,   r-   r   r   
ValueError)r%   framemsgs      r.   _ensure_lazyframer7   =   s0   #	9-.. xxzz	C	 	  ||~~""$$$	3		 
JsR\294M$N$N 
{3///e88 	%NN$$Ezz||	c		 3$.sRXr~4N$O$O ###%%%D*=c*B*BDDoor0   )	n_objectsnamedall_compatibler8   
int | Noner9   4str | Collection[str] | Callable[[str], bool] | Nonedict[str, Any]c                `    | rt           nt          t          t          f}t	          |||          S )z5Return compatible frame objects from the local stack.)of_typer8   r9   )r/   r   r   r   r   )r:   r8   r9   r?   s       r.   _get_frame_localsr@   P   s0     $2U	9f7UGW	OOOOr0   c                     e Zd ZU dZded<   ded<   ded<   e	 dQdd	d
dRd            Ze	 dQdddSd            Ze	 dQdddTd            Z eddd           	 dUd	d	d
dVd"            Zeed	d#dWd'                        Z	eedXd)                        Z	eedYd+                        Z	ed	d#dYd,            Z	dZd.Z
d[d5Zd\d6Zedd#d]d7            Zed^d8            Zed_d9            Zedd#d`d:            Zedad;            Zedbd<            Zedd#dcd?            Zd!d#dcd@ZdddDZ	 dUdEdFdedJZ	 dUdfdKZdgdNZdhdPZd!S )ir$   a   
    Run SQL queries against DataFrame, LazyFrame, and Series data.

    .. warning::
        This functionality is considered **unstable**, although it is close to being
        considered stable. It may be changed at any point without it being considered
        a breaking change.
    r   _ctxtzFinal[bool]_eager_executionzlist[set[str]]_tables_scope_stack.F)register_globalseagerselfSQLContext[LazyFrame]frames/Mapping[str, CompatibleFrameType | None] | NonerE   
bool | intrF   Literal[False]named_framesCompatibleFrameType | Noner&   Nonec                   d S N rG   rI   rE   rF   rM   s        r.   __init__zSQLContext.__init__o   	     sr0   )rE   SQLContext[DataFrame]Literal[True]c                   d S rQ   rR   rS   s        r.   rT   zSQLContext.__init__y   rU   r0   r'   c                   d S rQ   rR   rS   s        r.   rT   zSQLContext.__init__   rU   r0   eager_executionz0.20.31)versionNc               R   t          d           t          j                    | _        || _        t          |pi           }|r5t          d                                          D ]\  }}||vr	||vr|||<   |s|r,|                    |           | 	                    |           dS dS )u  
        Initialize a new `SQLContext`.

        .. versionchanged:: 0.20.31
            The `eager_execution` parameter was renamed `eager`.

        Parameters
        ----------
        frames
            A `{name:frame, ...}` mapping which can include Polars frames *and*
            pandas DataFrames, Series and pyarrow Table and RecordBatch objects.
        register_globals
            Register compatible objects (polars DataFrame, LazyFrame, and Series) found
            in the globals, automatically mapping their variable name to a table name.
            To register other objects (pandas/pyarrow data) pass them explicitly, or
            call the `execute_global` classmethod. If given an integer then only the
            most recent "n" objects found will be registered.
        eager
            If True, returns execution results as `DataFrame` instead of `LazyFrame`.
            (Note that the query itself is always executed in lazy-mode; this parameter
            impacts whether :meth:`execute` returns an eager or lazy result frame).
        **named_frames
            Named eager/lazy frames, provided as kwargs.

        Examples
        --------
        >>> lf = pl.LazyFrame({"a": [1, 2, 3], "b": ["x", None, "z"]})
        >>> res = pl.SQLContext(frame=lf).execute(
        ...     "SELECT b, a*2 AS two_a FROM frame WHERE b IS NOT NULL"
        ... )
        >>> res.collect()
        shape: (2, 2)
        ┌─────┬───────┐
        │ b   ┆ two_a │
        │ --- ┆ ---   │
        │ str ┆ i64   │
        ╞═════╪═══════╡
        │ x   ┆ 2     │
        │ z   ┆ 6     │
        └─────┴───────┘
        zY`SQLContext` is considered **unstable**, although it is close to being considered stable.Fr:   N)
r   r   newrB   rC   dictr@   itemsupdateregister_many)rG   rI   rE   rF   rM   namer%   s          r.   rT   zSQLContext.__init__   s    d 	g	
 	
 	
 "%''
 %fl## 	-.$  egg- -	c v%%$l*B*B),L& 	'\ 	'MM,'''v&&&&&	' 	'r0   )rF   querystrr   c                   d S rQ   rR   clsrd   rF   s      r.   execute_globalzSQLContext.execute_global   s	     Cr0   r   c                   d S rQ   rR   rg   s      r.   ri   zSQLContext.execute_global   s    ORsr0   DataFrame | LazyFramec                   d S rQ   rR   rg   s      r.   ri   zSQLContext.execute_global   s    RURUr0   c                   t          t          j        |dd                    }t          d|          } | |d          5 }|                    ||          cddd           S # 1 swxY w Y   dS )u  
        Immediately execute a SQL query, automatically registering frame globals.

        Notes
        -----
        * This convenience method automatically registers all compatible objects in
          the local stack that are referenced in the query, mapping their variable name
          to a table name. Note that in addition to polars DataFrame, LazyFrame, and
          Series this method *also* registers pandas DataFrame, Series, and pyarrow
          Table and RecordBatch objects.
        * Instead of calling this classmethod you should consider using `pl.sql`,
          which will use this code internally.

        Parameters
        ----------
        query
            A valid SQL query string.
        eager
            If True, returns execution results as `DataFrame` instead of `LazyFrame`.
            (Note that the query itself is always executed in lazy-mode).

        Examples
        --------
        >>> import pandas as pd
        >>> df = pl.LazyFrame({"a": [1, 2, 3], "b": [4, 5, 6]})
        >>> df_pandas = pd.DataFrame({"a": [2, 3, 4], "c": [7, 8, 9]})

        Join a polars LazyFrame with a pandas DataFrame (note use of the preferred
        `pl.sql` method, which is equivalent to `SQLContext.execute_global`):

        >>> pl.sql("SELECT df.*, c FROM df JOIN df_pandas USING(a)").collect()
        shape: (2, 3)
        ┌─────┬─────┬─────┐
        │ a   ┆ b   ┆ c   │
        │ --- ┆ --- ┆ --- │
        │ i64 ┆ i64 ┆ i64 │
        ╞═════╪═════╪═════╡
        │ 2   ┆ 5   ┆ 7   │
        │ 3   ┆ 6   ┆ 8   │
        └─────┴─────┴─────┘
        FT)include_schemaunique)r:   r9   )rI   rE   )rd   rF   N)setr   table_identifiersr@   execute)rh   rd   rF   table_namesrM   ctxs         r.   ri   zSQLContext.execute_global   s    ^ *$  
 
 )KPPPSu=== 	9;;U%;88	9 	9 	9 	9 	9 	9 	9 	9 	9 	9 	9 	9 	9 	9 	9 	9 	9 	9s   A''A+.A+SQLContext[FrameType]c                    t          | dg           | _        | j                            t          |                                                      | S )zITrack currently registered tables on scope entry; supports nested scopes.rD   )getattrrD   appendrp   tablesrG   s    r.   	__enter__zSQLContext.__enter__  sC    #*41F#K#K  ''DKKMM(:(:;;;r0   exc_typetype[BaseException] | Noneexc_valBaseException | Noneexc_tbTracebackType | Nonec                    |                      t          |                                           | j                                        z
             dS )z
        Unregister any tables created within the given scope on context exit.

        See Also
        --------
        unregister
        )namesN)
unregisterrp   ry   rD   pop)rG   r|   r~   r   s       r.   __exit__zSQLContext.__exit__   sP     	t{{}}%%(@(D(D(F(FF 	 	
 	
 	
 	
 	
r0   c                r    t          |                                           }d| dt          |           ddS )Nz<SQLContext [tables:z] at 0xx>)lenry   id)rG   n_tabless     r.   __repr__zSQLContext.__repr__1  s9    t{{}}%%DhDDr$xxDDDDDr0   c                   d S rQ   rR   rG   rd   rF   s      r.   rr   zSQLContext.execute8  	     Cr0   c                   d S rQ   rR   r   s      r.   rr   zSQLContext.execute=  r   r0   c                   d S rQ   rR   r   s      r.   rr   zSQLContext.executeB  r   r0   c                   d S rQ   rR   r   s      r.   rr   zSQLContext.executeG  r   r0   c                   d S rQ   rR   r   s      r.   rr   zSQLContext.executeL  r   r0   c                   d S rQ   rR   r   s      r.   rr   zSQLContext.executeQ  r   r0   bool | NoneLazyFrame | DataFramec                   d S rQ   rR   r   s      r.   rr   zSQLContext.executeV  s	     !$r0   c                   t          | j                            |                    }|s| j        r|                                n|S )u  
        Parse the given SQL query and execute it against the registered frame data.

        Parameters
        ----------
        query
            A valid string SQL query.
        eager
            Apply the query eagerly, returning `DataFrame` instead of `LazyFrame`.
            If unset, the value of the init-time "eager" parameter will be used.
            Note that the query itself is always executed in lazy-mode; this
            parameter only impacts the type of the returned frame.

        Examples
        --------
        Declare frame data and register with a SQLContext:

        >>> df = pl.DataFrame(
        ...     data=[
        ...         ("The Godfather", 1972, 6_000_000, 134_821_952, 9.2),
        ...         ("The Dark Knight", 2008, 185_000_000, 533_316_061, 9.0),
        ...         ("Schindler's List", 1993, 22_000_000, 96_067_179, 8.9),
        ...         ("Pulp Fiction", 1994, 8_000_000, 107_930_000, 8.9),
        ...         ("The Shawshank Redemption", 1994, 25_000_000, 28_341_469, 9.3),
        ...     ],
        ...     schema=["title", "release_year", "budget", "gross", "imdb_score"],
        ...     orient="row",
        ... )
        >>> ctx = pl.SQLContext(films=df)

        Execute a SQL query against the registered frame data:

        >>> ctx.execute(
        ...     '''
        ...     SELECT title, release_year, imdb_score
        ...     FROM films
        ...     WHERE release_year > 1990
        ...     ORDER BY imdb_score DESC
        ...     ''',
        ...     eager=True,
        ... )
        shape: (4, 3)
        ┌──────────────────────────┬──────────────┬────────────┐
        │ title                    ┆ release_year ┆ imdb_score │
        │ ---                      ┆ ---          ┆ ---        │
        │ str                      ┆ i64          ┆ f64        │
        ╞══════════════════════════╪══════════════╪════════════╡
        │ The Shawshank Redemption ┆ 1994         ┆ 9.3        │
        │ The Dark Knight          ┆ 2008         ┆ 9.0        │
        │ Schindler's List         ┆ 1993         ┆ 8.9        │
        │ Pulp Fiction             ┆ 1994         ┆ 8.9        │
        └──────────────────────────┴──────────────┴────────────┘

        Execute a GROUP BY query:

        >>> ctx.execute(
        ...     '''
        ...     SELECT
        ...         MAX(release_year / 10) * 10 AS decade,
        ...         SUM(gross) AS total_gross,
        ...         COUNT(title) AS n_films,
        ...     FROM films
        ...     GROUP BY (release_year / 10) -- decade
        ...     ORDER BY total_gross DESC
        ...     ''',
        ...     eager=True,
        ... )
        shape: (3, 3)
        ┌────────┬─────────────┬─────────┐
        │ decade ┆ total_gross ┆ n_films │
        │ ---    ┆ ---         ┆ ---     │
        │ i64    ┆ i64         ┆ u32     │
        ╞════════╪═════════════╪═════════╡
        │ 2000   ┆ 533316061   ┆ 1       │
        │ 1990   ┆ 232338648   ┆ 3       │
        │ 1970   ┆ 134821952   ┆ 1       │
        └────────┴─────────────┴─────────┘
        )r   rB   rr   rC   collect)rG   rd   rF   ress       r.   rr   zSQLContext.execute[  sA    b tz))%0011!&I$*?Is{{}}}cIr0   rc   r5   r"   c                    |t                      nt          |          }| j                            ||j                   | S )u  
        Register a single frame as a table, using the given name.

        Parameters
        ----------
        name
            Name of the table.
        frame
            eager/lazy frame to associate with this table name.

        See Also
        --------
        register_globals
        register_many
        unregister

        Examples
        --------
        >>> df = pl.DataFrame({"hello": ["world"]})
        >>> ctx = pl.SQLContext()
        >>> ctx.register("frame_data", df).execute("SELECT * FROM frame_data").collect()
        shape: (1, 1)
        ┌───────┐
        │ hello │
        │ ---   │
        │ str   │
        ╞═══════╡
        │ world │
        └───────┘
        )r   r7   rB   register_ldf)rG   rc   r5   s      r.   r   zSQLContext.register  s=    >  %}	2CE2J2J
D%*---r0   Tr]   nr;   r:   c               P    t          ||          }|                     |          S )u9  
        Register all frames (lazy or eager) found in the current globals scope.

        Automatically maps variable names to table names.

        See Also
        --------
        register
        register_many
        unregister

        Parameters
        ----------
        n
            Register only the most recent "n" frames.
        all_compatible
            Control whether we *also* register pandas DataFrame, Series, and
            pyarrow Table and RecordBatch objects. If False, only Polars
            classes are registered with the SQL engine.

        Examples
        --------
        >>> df1 = pl.DataFrame({"a": [1, 2, 3], "b": ["x", None, "z"]})
        >>> df2 = pl.DataFrame({"a": [2, 3, 4], "c": ["t", "w", "v"]})

        Register frames directly from variables found in the current globals scope:

        >>> ctx = pl.SQLContext(register_globals=True)
        >>> ctx.tables()
        ['df1', 'df2']

        Query using the register variable/frame names

        >>> ctx.execute(
        ...     "SELECT a, b, c FROM df1 LEFT JOIN df2 USING (a) ORDER BY a DESC"
        ... ).collect()
        shape: (3, 3)
        ┌─────┬──────┬──────┐
        │ a   ┆ b    ┆ c    │
        │ --- ┆ ---  ┆ ---  │
        │ i64 ┆ str  ┆ str  │
        ╞═════╪══════╪══════╡
        │ 3   ┆ z    ┆ w    │
        │ 2   ┆ null ┆ t    │
        │ 1   ┆ x    ┆ null │
        └─────┴──────┴──────┘
        )r:   r8   )rI   )r@   rb   )rG   r   r:   rI   s       r.   rE   zSQLContext.register_globals  s.    d #.ANNN!!!000r0   c                    t          |pi           }|                    |           |                                D ]\  }}|                     ||           | S )a   
        Register multiple eager/lazy frames as tables, using the associated names.

        Parameters
        ----------
        frames
            A `{name:frame, ...}` mapping.
        **named_frames
            Named eager/lazy frames, provided as kwargs.

        See Also
        --------
        register
        register_globals
        unregister

        Examples
        --------
        >>> lf1 = pl.LazyFrame({"a": [1, 2, 3], "b": ["m", "n", "o"]})
        >>> lf2 = pl.LazyFrame({"a": [2, 3, 4], "c": ["p", "q", "r"]})
        >>> lf3 = pl.LazyFrame({"a": [3, 4, 5], "b": ["s", "t", "u"]})
        >>> lf4 = pl.LazyFrame({"a": [4, 5, 6], "c": ["v", "w", "x"]})

        Register multiple frames at once, either by passing in as a dict...

        >>> ctx = pl.SQLContext().register_many({"tbl1": lf1, "tbl2": lf2})
        >>> ctx.tables()
        ['tbl1', 'tbl2']

        ...or using keyword args:

        >>> ctx.register_many(tbl3=lf3, tbl4=lf4).tables()
        ['tbl1', 'tbl2', 'tbl3', 'tbl4']
        )r_   ra   r`   r   )rG   rI   rM   rc   r5   s        r.   rb   zSQLContext.register_many  s_    N fl##l###!<<>> 	' 	'KD%MM$&&&&r0   r   str | Collection[str]c                t    t          |t                    r|g}|D ]}| j                            |           | S )a  
        Unregister one or more eager/lazy frames by name.

        Parameters
        ----------
        names
            Names of the tables to unregister.

        Notes
        -----
        You can also control table registration lifetime by using `SQLContext` as a
        context manager; this can often be more useful when such control is wanted:

        >>> df0 = pl.DataFrame({"colx": [0, 1, 2]})
        >>> df1 = pl.DataFrame({"colx": [1, 2, 3]})
        >>> df2 = pl.DataFrame({"colx": [2, 3, 4]})

        Frames registered in-scope are automatically unregistered on scope-exit. Note
        that frames registered on construction will persist through subsequent scopes.

        >>> # register one frame at construction time, and the other two in-scope
        >>> with pl.SQLContext(tbl0=df0) as ctx:
        ...     ctx.register_many(tbl1=df1, tbl2=df2).tables()
        ['tbl0', 'tbl1', 'tbl2']

        After scope exit, none of the tables registered in-scope remain:

        >>> ctx.tables()
        ['tbl0']

        See Also
        --------
        register
        register_globals
        register_many

        Examples
        --------
        >>> df0 = pl.DataFrame({"ints": [9, 8, 7, 6, 5]})
        >>> lf1 = pl.LazyFrame({"text": ["a", "b", "c"]})
        >>> lf2 = pl.LazyFrame({"misc": ["testing1234"]})

        Register with a SQLContext object:

        >>> ctx = pl.SQLContext(test1=df0, test2=lf1, test3=lf2)
        >>> ctx.tables()
        ['test1', 'test2', 'test3']

        Unregister one or more of the tables:

        >>> ctx.unregister(["test1", "test3"]).tables()
        ['test2']
        >>> ctx.unregister("test2").tables()
        []
        )r)   re   rB   r   )rG   r   nms      r.   r   zSQLContext.unregister4  sK    p eS!! 	GE 	& 	&BJ!!"%%%%r0   	list[str]c                N    t          | j                                                  S )u)  
        Return a list of the registered table names.

        Notes
        -----
        The :meth:`tables` method will return the same values as the
        "SHOW TABLES" SQL statement, but as a list instead of a frame.

        Executing as SQL:

        >>> frame_data = pl.DataFrame({"hello": ["world"]})
        >>> ctx = pl.SQLContext(hello_world=frame_data)
        >>> ctx.execute("SHOW TABLES", eager=True)
        shape: (1, 1)
        ┌─────────────┐
        │ name        │
        │ ---         │
        │ str         │
        ╞═════════════╡
        │ hello_world │
        └─────────────┘

        Calling the method:

        >>> ctx.tables()
        ['hello_world']

        Examples
        --------
        >>> df1 = pl.DataFrame({"hello": ["world"]})
        >>> df2 = pl.DataFrame({"foo": ["bar", "baz"]})
        >>> ctx = pl.SQLContext(hello_data=df1, foo_bar=df2)
        >>> ctx.tables()
        ['foo_bar', 'hello_data']
        )sortedrB   
get_tablesrz   s    r.   ry   zSQLContext.tablesr  s!    H dj++--...r0   ).)rG   rH   rI   rJ   rE   rK   rF   rL   rM   rN   r&   rO   )rG   rV   rI   rJ   rE   rK   rF   rW   rM   rN   r&   rO   )rG   rV   rI   rJ   rE   rK   rF   r'   rM   rN   r&   rO   rQ   )
rI   rJ   rE   rK   rF   r'   rM   rN   r&   rO   )rd   re   rF   rL   r&   r   )rd   re   rF   rW   r&   r   )rd   re   rF   r'   r&   rk   )r&   ru   )r|   r}   r~   r   r   r   r&   rO   )r&   re   )rG   rV   rd   re   rF   rO   r&   r   )rG   rV   rd   re   rF   rL   r&   r   )rG   rV   rd   re   rF   rW   r&   r   )rG   rH   rd   re   rF   rO   r&   r   )rG   rH   rd   re   rF   rL   r&   r   )rG   rH   rd   re   rF   rW   r&   r   )rd   re   rF   r   r&   r   )rc   re   r5   rN   r&   r"   )r   r;   r:   r'   r&   r"   )rI   rJ   rM   rN   r&   r"   )r   r   r&   r"   )r&   r   )__name__
__module____qualname____doc____annotations__r   rT   r   classmethodri   r{   r   r   rr   r   rE   rb   r   ry   rR   r0   r.   r$   r$   [   s          !!!!''''  CF (+ %     X  CF (+	     X  CF (+	     X ! !2GYOOO CGA' (-A' A' A' A' A' POA'F 49     [ X RRR [ XRUUU [ XU*/89 89 89 89 89 [89t   
 
 
 
"E E E E BE     X    X    X BE     X    X    X 25$ $ $ $ $ X$
 37RJ RJ RJ RJ RJ RJh! ! ! !H #31>B31 31 31 31 31 31n CG+ + + + +Z< < < <|$/ $/ $/ $/ $/ $/r0   )r%   r   r&   r'   )r%   r   r&   r   )r:   r'   r8   r;   r9   r<   r&   r=   )?
__future__r   
contextlibtypingr   r   r   polars._dependenciesr   r   r	   r*   r
   r+   polars._typingr   polars._utils.deprecationr   polars._utils.pycapsuler   polars._utils.unstabler   polars._utils.variousr   r   polars._utils.wrapr   polars.convertr   r   polars.dataframer   polars.lazyframer   polars.seriesr   suppressImportErrorpolars._plrr   syscollections.abcr   r   r   typesr   r   r   r   r   version_infor"   typing_extensionsr,   r-   r#   r   __all__r/   r7   r@   r$   rR   r0   r.   <module>r      so   " " " " " " "              G F F F F F F F - - - - - - . . . . . . $ $ $ $ $ $ A A A A A A 0 0 0 0 0 0 9 9 9 9 9 9 H H H H H H H H ' ' ' ' ' ' 2 2 2 2 2 2 2 2 & & & & & & & & & & & &            Z%% ) )(((((() ) ) ) ) ) ) ) ) ) ) ) ) ) )  JJJ==========######555555555555
7""****** 	
	
	 ,	 )C.		
 (	 .	      .      , !BF	P P P P P P{/ {/ {/ {/ {/# {/ {/ {/ {/ {/s   :BBB