sqlframe 3.6.0__tar.gz → 3.8.0__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {sqlframe-3.6.0 → sqlframe-3.8.0}/PKG-INFO +1 -1
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/bigquery.md +1 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/duckdb.md +3 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/snowflake.md +4 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/setup.py +4 -4
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/_version.py +2 -2
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/function_alternatives.py +1 -1
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/functions.py +11 -11
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/mixins/readwriter_mixins.py +1 -1
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/readerwriter.py +39 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/readwriter.py +1 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe.egg-info/PKG-INFO +1 -1
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe.egg-info/requires.txt +4 -4
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_functions.py +4 -2
- {sqlframe-3.6.0 → sqlframe-3.8.0}/.github/CODEOWNERS +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/.github/workflows/main.workflow.yaml +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/.github/workflows/publish.workflow.yaml +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/.gitignore +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/.pre-commit-config.yaml +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/.readthedocs.yaml +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/LICENSE +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/Makefile +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/README.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/add_chatgpt_support.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/adding_ai_to_meal.jpeg +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/hype_train.gif +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/marvin_paranoid_robot.gif +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/nonsense_sql.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/openai_full_rewrite.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/openai_replacing_cte_names.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/sqlglot_optimized_code.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/sunny_shake_head_no.gif +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/but_wait_theres_more.gif +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/cake.gif +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/you_get_pyspark_api.gif +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/sqlframe_universal_dataframe_api.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/configuration.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/docs/bigquery.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/docs/duckdb.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/docs/images/SF.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/docs/images/favicon.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/docs/images/favicon_old.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/docs/images/sqlframe_diagram.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/docs/images/sqlframe_logo.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/docs/postgres.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/images/SF.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/images/favicon.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/images/favicon_old.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/images/sqlframe_diagram.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/images/sqlframe_logo.png +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/index.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/postgres.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/requirements.txt +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/spark.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/standalone.md +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/docs/stylesheets/extra.css +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/mkdocs.yml +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/pytest.ini +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/renovate.json +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/setup.cfg +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/LICENSE +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/_typing.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/decorators.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/exceptions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/group.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/mixins/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/mixins/catalog_mixins.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/mixins/dataframe_mixins.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/normalize.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/operations.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/transforms.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/util.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/base/window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/functions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/functions.pyi +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/group.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/readwriter.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/bigquery/window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/functions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/functions.pyi +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/group.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/duckdb/window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/functions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/functions.pyi +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/group.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/readwriter.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/postgres/window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/functions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/group.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/readwriter.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/redshift/window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/functions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/functions.pyi +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/group.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/readwriter.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/snowflake/window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/functions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/functions.pyi +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/group.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/readwriter.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/spark/window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/functions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/group.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/readwriter.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/standalone/window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/testing/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe/testing/utils.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe.egg-info/SOURCES.txt +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe.egg-info/dependency_links.txt +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/sqlframe.egg-info/top_level.txt +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/common_fixtures.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/conftest.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee.csv +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee.json +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee.parquet +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/.part-00000-e5965c7b-e58f-4d3c-ad56-002876814e3a-c000.snappy.parquet.crc +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/.part-00002-3fed7f18-370f-4b16-b232-504d6194eb52-c000.snappy.parquet.crc +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/.part-00004-143c5da1-d5ab-4706-8e84-0d2a324c6894-c000.snappy.parquet.crc +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/.part-00006-64f07e25-c30e-4075-acc6-b3c69c4ce80b-c000.snappy.parquet.crc +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/.part-00008-89ccad8d-df73-4ad5-8850-82ef3884db60-c000.snappy.parquet.crc +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/.part-00010-812b3382-8c7f-4c4e-9bcd-09ce8664f6e0-c000.snappy.parquet.crc +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/_delta_log/.00000000000000000000.json.crc +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/_delta_log/00000000000000000000.json +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/part-00000-e5965c7b-e58f-4d3c-ad56-002876814e3a-c000.snappy.parquet +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/part-00002-3fed7f18-370f-4b16-b232-504d6194eb52-c000.snappy.parquet +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/part-00004-143c5da1-d5ab-4706-8e84-0d2a324c6894-c000.snappy.parquet +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/part-00006-64f07e25-c30e-4075-acc6-b3c69c4ce80b-c000.snappy.parquet +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/part-00008-89ccad8d-df73-4ad5-8850-82ef3884db60-c000.snappy.parquet +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_delta/part-00010-812b3382-8c7f-4c4e-9bcd-09ce8664f6e0-c000.snappy.parquet +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/employee_extra_line.csv +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds1.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds10.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds11.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds12.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds13.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds14.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds15.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds16.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds17.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds18.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds19.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds2.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds20.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds21.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds22.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds23.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds24.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds25.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds26.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds27.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds28.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds29.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds3.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds30.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds31.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds32.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds33.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds34.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds35.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds36.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds37.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds38.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds39.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds4.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds40.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds41.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds42.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds43.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds44.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds45.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds46.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds47.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds48.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds49.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds5.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds50.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds51.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds52.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds53.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds54.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds55.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds56.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds57.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds58.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds59.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds6.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds60.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds61.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds62.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds63.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds64.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds65.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds66.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds67.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds68.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds69.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds7.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds70.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds71.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds72.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds73.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds74.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds75.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds76.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds77.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds78.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds79.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds8.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds80.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds81.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds82.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds83.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds84.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds85.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds86.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds87.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds88.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds89.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds9.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds90.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds91.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds92.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds93.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds94.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds95.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds96.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds97.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds98.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/fixtures/tpcds/tpcds99.sql +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/bigquery/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/bigquery/test_bigquery_catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/bigquery/test_bigquery_dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/bigquery/test_bigquery_session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/duck/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/duck/test_duckdb_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/duck/test_duckdb_catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/duck/test_duckdb_dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/duck/test_duckdb_reader.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/duck/test_duckdb_session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/duck/test_duckdb_udf.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/duck/test_tpcds.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/postgres/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/postgres/test_postgres_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/postgres/test_postgres_catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/postgres/test_postgres_dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/postgres/test_postgres_session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/redshift/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/redshift/test_redshift_catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/redshift/test_redshift_session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/snowflake/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/snowflake/test_snowflake_catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/snowflake/test_snowflake_dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/snowflake/test_snowflake_session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/spark/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/spark/test_spark_catalog.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/spark/test_spark_dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/test_engine_column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/test_engine_dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/test_engine_reader.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/test_engine_session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/test_engine_writer.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/test_int_functions.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/engines/test_int_testing.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/fixtures.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/test_int_dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/test_int_dataframe_stats.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/test_int_grouped_data.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/integration/test_int_session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/bigquery/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/bigquery/test_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/conftest.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/duck/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/duck/test_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/postgres/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/postgres/test_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/redshift/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/redshift/test_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/snowflake/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/snowflake/test_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/spark/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/spark/test_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/__init__.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/fixtures.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_column.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_dataframe.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_dataframe_writer.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_session.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_session_case_sensitivity.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_types.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/standalone/test_window.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/test_activate.py +0 -0
- {sqlframe-3.6.0 → sqlframe-3.8.0}/tests/unit/test_util.py +0 -0
| @@ -425,6 +425,7 @@ See something that you would like to see supported? [Open an issue](https://gith | |
| 425 425 | 
             
            * [max_by](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.max_by.html)
         | 
| 426 426 | 
             
            * [md5](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.md5.html)
         | 
| 427 427 | 
             
            * [mean](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.mean.html)
         | 
| 428 | 
            +
            * [median](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.median.html)
         | 
| 428 429 | 
             
            * [min](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.min.html)
         | 
| 429 430 | 
             
            * [min_by](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.min_by.html)
         | 
| 430 431 | 
             
            * [minute](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.minute.html)
         | 
| @@ -308,6 +308,8 @@ See something that you would like to see supported? [Open an issue](https://gith | |
| 308 308 | 
             
            * [concat](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.concat.html)                               
         | 
| 309 309 | 
             
                * Only works on strings (does not work on arrays)
         | 
| 310 310 | 
             
            * [concat_ws](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.concat_ws.html)
         | 
| 311 | 
            +
            * [contains](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.contains.html)
         | 
| 312 | 
            +
              * Only works on strings (does not support binary)
         | 
| 311 313 | 
             
            * [convert_timezone](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.convert_timezone.html)
         | 
| 312 314 | 
             
            * [corr](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.corr.html)
         | 
| 313 315 | 
             
            * [cos](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.cos.html)
         | 
| @@ -395,6 +397,7 @@ See something that you would like to see supported? [Open an issue](https://gith | |
| 395 397 | 
             
            * [max_by](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.max_by.html)
         | 
| 396 398 | 
             
            * [md5](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.md5.html)
         | 
| 397 399 | 
             
            * [mean](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.mean.html)
         | 
| 400 | 
            +
            * [median](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.median.html)
         | 
| 398 401 | 
             
            * [min](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.min.html)
         | 
| 399 402 | 
             
            * [min_by](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.min_by.html)
         | 
| 400 403 | 
             
            * [minute](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.minute.html)
         | 
| @@ -344,6 +344,8 @@ See something that you would like to see supported? [Open an issue](https://gith | |
| 344 344 | 
             
            * [concat](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.concat.html)
         | 
| 345 345 | 
             
              * Can only concat strings not arrays
         | 
| 346 346 | 
             
            * [concat_ws](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.concat_ws.html)
         | 
| 347 | 
            +
            * [contains](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.contains.html)
         | 
| 348 | 
            +
              * * Only works on strings (does not support binary)
         | 
| 347 349 | 
             
            * [convert_timezone](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.convert_timezone.html)
         | 
| 348 350 | 
             
            * [corr](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.corr.html)
         | 
| 349 351 | 
             
            * [cos](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.cos.html)
         | 
| @@ -428,6 +430,7 @@ See something that you would like to see supported? [Open an issue](https://gith | |
| 428 430 | 
             
            * [max_by](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.max_by.html)
         | 
| 429 431 | 
             
            * [md5](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.md5.html)
         | 
| 430 432 | 
             
            * [mean](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.mean.html)
         | 
| 433 | 
            +
            * [median](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.median.html)
         | 
| 431 434 | 
             
            * [min](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.min.html)
         | 
| 432 435 | 
             
            * [min_by](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.min_by.html)
         | 
| 433 436 | 
             
            * [minute](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.minute.html)
         | 
| @@ -510,6 +513,7 @@ See something that you would like to see supported? [Open an issue](https://gith | |
| 510 513 | 
             
            * [ucase](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.ucase.html)
         | 
| 511 514 | 
             
            * [unbase64](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.unbase64.html)
         | 
| 512 515 | 
             
            * [unhex](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.unhex.html)
         | 
| 516 | 
            +
            * [unix_seconds](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.unix_seconds.html)
         | 
| 513 517 | 
             
            * [unix_timestamp](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.unix_timestamp.html)
         | 
| 514 518 | 
             
            * [upper](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.upper.html)
         | 
| 515 519 | 
             
            * [var_pop](https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.var_pop.html)
         | 
| @@ -19,8 +19,8 @@ setup( | |
| 19 19 | 
             
                setup_requires=["setuptools_scm"],
         | 
| 20 20 | 
             
                python_requires=">=3.8",
         | 
| 21 21 | 
             
                install_requires=[
         | 
| 22 | 
            -
                    "prettytable<3. | 
| 23 | 
            -
                    "sqlglot>=24.0.0,<25. | 
| 22 | 
            +
                    "prettytable<3.12.1",
         | 
| 23 | 
            +
                    "sqlglot>=24.0.0,<25.32",
         | 
| 24 24 | 
             
                    "typing_extensions>=4.8,<5",
         | 
| 25 25 | 
             
                ],
         | 
| 26 26 | 
             
                extras_require={
         | 
| @@ -32,7 +32,7 @@ setup( | |
| 32 32 | 
             
                        "duckdb>=0.9,<1.2",
         | 
| 33 33 | 
             
                        "findspark>=2,<3",
         | 
| 34 34 | 
             
                        "mypy>=1.10.0,<1.14",
         | 
| 35 | 
            -
                        "openai>=1.30,<1. | 
| 35 | 
            +
                        "openai>=1.30,<1.55",
         | 
| 36 36 | 
             
                        "pandas>=2,<3",
         | 
| 37 37 | 
             
                        "pandas-stubs>=2,<3",
         | 
| 38 38 | 
             
                        "psycopg>=3.1,<4",
         | 
| @@ -58,7 +58,7 @@ setup( | |
| 58 58 | 
             
                        "pandas>=2,<3",
         | 
| 59 59 | 
             
                    ],
         | 
| 60 60 | 
             
                    "openai": [
         | 
| 61 | 
            -
                        "openai>=1.30,<1. | 
| 61 | 
            +
                        "openai>=1.30,<1.55",
         | 
| 62 62 | 
             
                    ],
         | 
| 63 63 | 
             
                    "pandas": [
         | 
| 64 64 | 
             
                        "pandas>=2,<3",
         | 
| @@ -1593,7 +1593,7 @@ def try_to_timestamp_pgtemp(col: ColumnOrName, format: t.Optional[ColumnOrName] | |
| 1593 1593 | 
             
            def typeof_pg_typeof(col: ColumnOrName) -> Column:
         | 
| 1594 1594 | 
             
                return (
         | 
| 1595 1595 | 
             
                    Column.invoke_anonymous_function(col, "pg_typeof")
         | 
| 1596 | 
            -
                    .cast(expression.DataType. | 
| 1596 | 
            +
                    .cast(expression.DataType(this=expression.DataType.Type.USERDEFINED, kind="regtype"))
         | 
| 1597 1597 | 
             
                    .cast("text")
         | 
| 1598 1598 | 
             
                )
         | 
| 1599 1599 |  | 
| @@ -2069,9 +2069,11 @@ def character_length(str: ColumnOrName) -> Column: | |
| 2069 2069 | 
             
                return Column.invoke_anonymous_function(str, "character_length")
         | 
| 2070 2070 |  | 
| 2071 2071 |  | 
| 2072 | 
            -
            @meta()
         | 
| 2072 | 
            +
            @meta(unsupported_engines=["bigquery", "postgres"])
         | 
| 2073 2073 | 
             
            def contains(left: ColumnOrName, right: ColumnOrName) -> Column:
         | 
| 2074 | 
            -
                return Column. | 
| 2074 | 
            +
                return Column.invoke_expression_over_column(
         | 
| 2075 | 
            +
                    left, expression.Contains, expression=Column.ensure_col(right).expression
         | 
| 2076 | 
            +
                )
         | 
| 2075 2077 |  | 
| 2076 2078 |  | 
| 2077 2079 | 
             
            @meta(unsupported_engines=["bigquery", "postgres"])
         | 
| @@ -3484,7 +3486,7 @@ def mask( | |
| 3484 3486 | 
             
                )
         | 
| 3485 3487 |  | 
| 3486 3488 |  | 
| 3487 | 
            -
            @meta(unsupported_engines=" | 
| 3489 | 
            +
            @meta(unsupported_engines=["bigquery"])
         | 
| 3488 3490 | 
             
            def median(col: ColumnOrName) -> Column:
         | 
| 3489 3491 | 
             
                """
         | 
| 3490 3492 | 
             
                Returns the median of the values in a group.
         | 
| @@ -3520,7 +3522,7 @@ def median(col: ColumnOrName) -> Column: | |
| 3520 3522 | 
             
                |dotNET|         10000.0|
         | 
| 3521 3523 | 
             
                +------+----------------+
         | 
| 3522 3524 | 
             
                """
         | 
| 3523 | 
            -
                return Column. | 
| 3525 | 
            +
                return Column.invoke_expression_over_column(col, expression.Median)
         | 
| 3524 3526 |  | 
| 3525 3527 |  | 
| 3526 3528 | 
             
            @meta(unsupported_engines="*")
         | 
| @@ -4106,11 +4108,9 @@ def regexp_extract_all( | |
| 4106 4108 | 
             
                >>> df.select(regexp_extract_all('str', col("regexp")).alias('d')).collect()
         | 
| 4107 4109 | 
             
                [Row(d=['100', '300'])]
         | 
| 4108 4110 | 
             
                """
         | 
| 4109 | 
            -
                 | 
| 4110 | 
            -
                     | 
| 4111 | 
            -
                 | 
| 4112 | 
            -
                    idx = lit(idx) if isinstance(idx, int) else idx
         | 
| 4113 | 
            -
                    return Column.invoke_anonymous_function(str, "regexp_extract_all", regexp, idx)
         | 
| 4111 | 
            +
                return Column.invoke_expression_over_column(
         | 
| 4112 | 
            +
                    str, expression.RegexpExtractAll, expression=regexp, group=idx
         | 
| 4113 | 
            +
                )
         | 
| 4114 4114 |  | 
| 4115 4115 |  | 
| 4116 4116 | 
             
            @meta(unsupported_engines="*")
         | 
| @@ -5426,7 +5426,7 @@ def unix_millis(col: ColumnOrName) -> Column: | |
| 5426 5426 | 
             
                return Column.invoke_anonymous_function(col, "unix_millis")
         | 
| 5427 5427 |  | 
| 5428 5428 |  | 
| 5429 | 
            -
            @meta(unsupported_engines=" | 
| 5429 | 
            +
            @meta(unsupported_engines=["bigquery", "duckdb", "postgres"])
         | 
| 5430 5430 | 
             
            def unix_seconds(col: ColumnOrName) -> Column:
         | 
| 5431 5431 | 
             
                """Returns the number of seconds since 1970-01-01 00:00:00 UTC.
         | 
| 5432 5432 | 
             
                Truncates higher levels of precision.
         | 
| @@ -5441,7 +5441,7 @@ def unix_seconds(col: ColumnOrName) -> Column: | |
| 5441 5441 | 
             
                [Row(n=1437584400)]
         | 
| 5442 5442 | 
             
                >>> spark.conf.unset("spark.sql.session.timeZone")
         | 
| 5443 5443 | 
             
                """
         | 
| 5444 | 
            -
                return Column. | 
| 5444 | 
            +
                return Column.invoke_expression_over_column(col, expression.UnixSeconds)
         | 
| 5445 5445 |  | 
| 5446 5446 |  | 
| 5447 5447 | 
             
            @meta(unsupported_engines="*")
         | 
| @@ -75,7 +75,7 @@ class PandasLoaderMixin(_BaseDataFrameReader, t.Generic[SESSION, DF]): | |
| 75 75 |  | 
| 76 76 | 
             
                    assert path is not None, "path is required"
         | 
| 77 77 | 
             
                    assert isinstance(path, str), "path must be a string"
         | 
| 78 | 
            -
                    format = format or _infer_format(path)
         | 
| 78 | 
            +
                    format = format or self.state_format_to_read or _infer_format(path)
         | 
| 79 79 | 
             
                    kwargs = {k: v for k, v in options.items() if v is not None}
         | 
| 80 80 | 
             
                    if format == "json":
         | 
| 81 81 | 
             
                        df = pd.read_json(path, lines=True, **kwargs)  # type: ignore
         | 
| @@ -36,6 +36,7 @@ logger = logging.getLogger(__name__) | |
| 36 36 | 
             
            class _BaseDataFrameReader(t.Generic[SESSION, DF]):
         | 
| 37 37 | 
             
                def __init__(self, spark: SESSION):
         | 
| 38 38 | 
             
                    self._session = spark
         | 
| 39 | 
            +
                    self.state_format_to_read: t.Optional[str] = None
         | 
| 39 40 |  | 
| 40 41 | 
             
                @property
         | 
| 41 42 | 
             
                def session(self) -> SESSION:
         | 
| @@ -67,6 +68,44 @@ class _BaseDataFrameReader(t.Generic[SESSION, DF]): | |
| 67 68 | 
             
                        for k, v in column_mapping.items()
         | 
| 68 69 | 
             
                    ]
         | 
| 69 70 |  | 
| 71 | 
            +
                def format(self, source: str) -> "Self":
         | 
| 72 | 
            +
                    """Specifies the input data source format.
         | 
| 73 | 
            +
             | 
| 74 | 
            +
                    .. versionadded:: 1.4.0
         | 
| 75 | 
            +
             | 
| 76 | 
            +
                    .. versionchanged:: 3.4.0
         | 
| 77 | 
            +
                        Supports Spark Connect.
         | 
| 78 | 
            +
             | 
| 79 | 
            +
                    Parameters
         | 
| 80 | 
            +
                    ----------
         | 
| 81 | 
            +
                    source : str
         | 
| 82 | 
            +
                        string, name of the data source, e.g. 'json', 'parquet'.
         | 
| 83 | 
            +
             | 
| 84 | 
            +
                    Examples
         | 
| 85 | 
            +
                    --------
         | 
| 86 | 
            +
                    >>> spark.read.format('json')
         | 
| 87 | 
            +
                    <...readwriter.DataFrameReader object ...>
         | 
| 88 | 
            +
             | 
| 89 | 
            +
                    Write a DataFrame into a JSON file and read it back.
         | 
| 90 | 
            +
             | 
| 91 | 
            +
                    >>> import tempfile
         | 
| 92 | 
            +
                    >>> with tempfile.TemporaryDirectory() as d:
         | 
| 93 | 
            +
                    ...     # Write a DataFrame into a JSON file
         | 
| 94 | 
            +
                    ...     spark.createDataFrame(
         | 
| 95 | 
            +
                    ...         [{"age": 100, "name": "Hyukjin Kwon"}]
         | 
| 96 | 
            +
                    ...     ).write.mode("overwrite").format("json").save(d)
         | 
| 97 | 
            +
                    ...
         | 
| 98 | 
            +
                    ...     # Read the JSON file as a DataFrame.
         | 
| 99 | 
            +
                    ...     spark.read.format('json').load(d).show()
         | 
| 100 | 
            +
                    +---+------------+
         | 
| 101 | 
            +
                    |age|        name|
         | 
| 102 | 
            +
                    +---+------------+
         | 
| 103 | 
            +
                    |100|Hyukjin Kwon|
         | 
| 104 | 
            +
                    +---+------------+
         | 
| 105 | 
            +
                    """
         | 
| 106 | 
            +
                    self.state_format_to_read = source
         | 
| 107 | 
            +
                    return self
         | 
| 108 | 
            +
             | 
| 70 109 | 
             
                def load(
         | 
| 71 110 | 
             
                    self,
         | 
| 72 111 | 
             
                    path: t.Optional[PathOrPaths] = None,
         | 
| @@ -72,6 +72,7 @@ class DuckDBDataFrameReader(_BaseDataFrameReader["DuckDBSession", "DuckDBDataFra | |
| 72 72 | 
             
                    |100|NULL|
         | 
| 73 73 | 
             
                    +---+----+
         | 
| 74 74 | 
             
                    """
         | 
| 75 | 
            +
                    format = format or self.state_format_to_read
         | 
| 75 76 | 
             
                    if schema:
         | 
| 76 77 | 
             
                        column_mapping = ensure_column_mapping(schema)
         | 
| 77 78 | 
             
                        select_column_mapping = column_mapping.copy()
         | 
| @@ -1,5 +1,5 @@ | |
| 1 | 
            -
            prettytable<3. | 
| 2 | 
            -
            sqlglot<25. | 
| 1 | 
            +
            prettytable<3.12.1
         | 
| 2 | 
            +
            sqlglot<25.32,>=24.0.0
         | 
| 3 3 | 
             
            typing_extensions<5,>=4.8
         | 
| 4 4 |  | 
| 5 5 | 
             
            [bigquery]
         | 
| @@ -10,7 +10,7 @@ google-cloud-bigquery[pandas]<4,>=3 | |
| 10 10 | 
             
            duckdb<1.2,>=0.9
         | 
| 11 11 | 
             
            findspark<3,>=2
         | 
| 12 12 | 
             
            mypy<1.14,>=1.10.0
         | 
| 13 | 
            -
            openai<1. | 
| 13 | 
            +
            openai<1.55,>=1.30
         | 
| 14 14 | 
             
            pandas-stubs<3,>=2
         | 
| 15 15 | 
             
            pandas<3,>=2
         | 
| 16 16 | 
             
            psycopg<4,>=3.1
         | 
| @@ -40,7 +40,7 @@ duckdb<1.2,>=0.9 | |
| 40 40 | 
             
            pandas<3,>=2
         | 
| 41 41 |  | 
| 42 42 | 
             
            [openai]
         | 
| 43 | 
            -
            openai<1. | 
| 43 | 
            +
            openai<1.55,>=1.30
         | 
| 44 44 |  | 
| 45 45 | 
             
            [pandas]
         | 
| 46 46 | 
             
            pandas<3,>=2
         | 
| @@ -13,9 +13,11 @@ from sqlframe.standalone import functions as SF | |
| 13 13 | 
             
            @pytest.mark.parametrize("name,func", inspect.getmembers(SF, inspect.isfunction))
         | 
| 14 14 | 
             
            def test_invoke_anonymous(name, func):
         | 
| 15 15 | 
             
                # array_size - converts to `size` but `array_size` and `size` behave differently
         | 
| 16 | 
            +
                # exists - the spark exists takes a lambda function and the exists in SQLGlot seems more basic
         | 
| 17 | 
            +
                # make_interval - SQLGlot doesn't support week
         | 
| 16 18 | 
             
                # to_char - convert to a cast that ignores the format provided
         | 
| 17 19 | 
             
                # ltrim/rtrim - don't seem to convert correctly on some engines
         | 
| 18 | 
            -
                ignore_funcs = {"array_size", "to_char", "ltrim", "rtrim"}
         | 
| 20 | 
            +
                ignore_funcs = {"array_size", "exists", "make_interval", "to_char", "ltrim", "rtrim"}
         | 
| 19 21 | 
             
                if "invoke_anonymous_function" in inspect.getsource(func) and name not in ignore_funcs:
         | 
| 20 22 | 
             
                    func = parse_one(f"{name}()", read="spark", error_level=ErrorLevel.IGNORE)
         | 
| 21 23 | 
             
                    assert isinstance(func, exp.Anonymous)
         | 
| @@ -4224,7 +4226,7 @@ def test_regexp_count(expression, expected): | |
| 4224 4226 | 
             
                        SF.regexp_extract_all("cola", "colb", SF.col("colc")),
         | 
| 4225 4227 | 
             
                        "REGEXP_EXTRACT_ALL(cola, colb, colc)",
         | 
| 4226 4228 | 
             
                    ),
         | 
| 4227 | 
            -
                    (SF.regexp_extract_all("cola", "colb",  | 
| 4229 | 
            +
                    (SF.regexp_extract_all("cola", "colb", 2), "REGEXP_EXTRACT_ALL(cola, colb, 2)"),
         | 
| 4228 4230 | 
             
                ],
         | 
| 4229 4231 | 
             
            )
         | 
| 4230 4232 | 
             
            def test_regexp_extract_all(expression, expected):
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
    
        {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/marvin_paranoid_robot.gif
    RENAMED
    
    | 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
    
        {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/openai_replacing_cte_names.png
    RENAMED
    
    | 
            File without changes
         | 
    
        {sqlframe-3.6.0 → sqlframe-3.8.0}/blogs/images/add_chatgpt_support/sqlglot_optimized_code.png
    RENAMED
    
    | 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         |