Skip to main content

Adds CreateView and DropView constructs to SQLAlchemy

Project description

Adds CreateView and DropView constructs to SQLAlchemy.

Status

Current version is 0.3.2; releases are infrequent as the code here is small and based on stable pieces of the SQLAlchemy API, so there has been minimal maintenance required so far to keep compatibility with new SQLAlchemy or python versions.

This package is working with latest Python and SQLAlchemy (1.0+ and 2.0) as of early 2023.

Usage

Examples:

>>> from sqlalchemy import Table, MetaData
>>> from sqlalchemy.sql import text
>>> from sqlalchemy_views import CreateView, DropView
>>> view = Table('my_view', MetaData())
>>> definition = text("SELECT * FROM my_table")
>>> create_view = CreateView(view, definition)
>>> print(str(create_view.compile()).strip())
CREATE VIEW my_view AS SELECT * FROM my_table
>>> create_view = CreateView(view, definition, or_replace=True)
>>> print(str(create_view.compile()).strip())
CREATE OR REPLACE VIEW my_view AS SELECT * FROM my_table
>>> create_view = CreateView(view, definition, options={'check_option': 'local'})
>>> print(str(create_view.compile()).strip())
CREATE VIEW my_view WITH (check_option=local) AS SELECT * FROM my_table
>>> drop_view = DropView(view)
>>> print(str(drop_view.compile()).strip())
DROP VIEW my_view
>>> drop_view = DropView(view, if_exists=True, cascade=True)
>>> print(str(drop_view.compile()).strip())
DROP VIEW IF EXISTS my_view CASCADE

Note that the SQLAlchemy Table object is used to represent both tables and views. To introspect a view, create a Table with autoload=True, and then use SQLAlchemy’s get_view_definition method to generate the second argument to CreateView.

Installation

sqlalchemy-views is available on PyPI and can be installed via pip

pip install sqlalchemy-views

Limitations

Various SQL dialects have developed custom CREATE VIEW and DROP VIEW syntax. This project aims to provide the core set of functionality shared by most database engines.

Acknowledgements

Some design ideas taken from the SQLAlchemy Usage Recipe for views.

Package structure is based on python-project-template.

And thank you to the various contributors!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sqlalchemy-views-0.3.2.tar.gz (18.9 kB view details)

Uploaded Source

Built Distribution

sqlalchemy_views-0.3.2-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file sqlalchemy-views-0.3.2.tar.gz.

File metadata

  • Download URL: sqlalchemy-views-0.3.2.tar.gz
  • Upload date:
  • Size: 18.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.4

File hashes

Hashes for sqlalchemy-views-0.3.2.tar.gz
Algorithm Hash digest
SHA256 c396416939bc4459c71f15c0279b72c9eb1f92fe022afe7fa74ed3adeef76e3b
MD5 1c77f654dfb81ec339c86556600a23f1
BLAKE2b-256 cb9b08dbe2c33ccc2e901fd31de1e2fec79df0ba788e1d08c688f18ac1c00e5d

See more details on using hashes here.

File details

Details for the file sqlalchemy_views-0.3.2-py3-none-any.whl.

File metadata

File hashes

Hashes for sqlalchemy_views-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 53a376efc8badbbd6d2d360f0d03fc70f1f5ee7748cf169506ea8a6e4f20326c
MD5 624a7d29ebee5bc1abe08aee7435d111
BLAKE2b-256 afab2802a1a5b4a3c5d6ef28c680cafbdca6345639778be56ce8a0862ea0d164

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page