A Python package for simplified SQL operations across MSSQL, PostgreSQL, MySQL, and SQLite.
Project description
SQLPy
SQLPy (sql_pydb) is a Python library to bridge the gap between Python and Database Tables.
Instalation Guide
pip install sql_pydb
- sql_pydb requires the following packages: Pandas, Numpy, pyodbc, python-dateutil
Overview:
- You can connect to MSSQL and SQLite.
- You can perform operations such as:
- Create Database(s)
- Create Table(s)
- Drop Column(s)
- Add Column(s)
- Alter Column Types (If database supports it)
- Performs a Try Cast check to be safe. (i.e. VARCHAR to INTEGER)
- Read from Table
- Delete from Table
- Drop Table(s)
Usage
- Example: Upload Pandas DataFrame to a MSSQL Database
from sql_pydb.Database import DatabaseType
from sql_pydb.Table import TableActions
table = TableActions(database=DATABASE, table_name=TABLE_NAME,
driver="ODBC Driver 17 for SQL Server",
server="url,port",
username="admin",
password="admin",
db_type=DatabaseType.MSSQL)
df = pd.read_csv("...file.csv")
table.identify_schema(df) # Figures out the best column types. Only needed 1 time per TableActions instance
table.sync_schema(update_column_types=True, add_new_columns=True, delete_old_columns=False) # Optional
status = table.insert_df(df, batch=1_000)
assert status == True
- Example: Upload Pandas DataFrame to a SQLite Database
from sql_pydb.Database import DatabaseType
from sql_pydb.Table import TableActions
table = TableActions(table_name=TABLE_NAME,
sqlite_path = SQLITE_PATH, # "./path/file.db"
db_type=DatabaseType.SQLITE)
df = pd.read_csv("...file.csv")
table.identify_schema(df) # Figures out the best column types. Only needed 1 time per TableActions instance
table.sync_schema(update_column_types=True, add_new_columns=True, delete_old_columns=False) # Optional
status = table.insert_df(df, batch=1_000)
assert status == True
- Example: Query Table
table = TableActions(...)
# ...
command = table.generate_select_all_sql()
df = table.run_query(command) # Returns pd.DataFrame
- Example: Execute Transactions
table = TableActions(...)
# ...
command1 = table.generate_add_columns_sql()
command2 = table.generate_drop_column_sql(column_name="UNUSED_COLUMN")
# ...
commandX = table.generate_insert_sql(df_new_records)
status = table.run_transaction([command1, command2, ..., commandX])
assert status == True
- Example: Create Table
from sql_pydb.Column import Column
from sql_pydb.Table import TableActions
table = TableActions(...)
# ...
user_defined_columns = [
Column("FIRST_NAME", data_type="VARCHAR", size=100),
...
Column("ADDRESS", data_type="VARCHAR"), # Default 255 for strings
]
table.identify_schema(df, user_defined_columns)
# Option 1: Let it automatically sync with the new defined columns
status = table.sync_schema(update_column_types=True, add_new_columns=True, delete_old_columns=False)
# Option 2: Manually create the table
command = table.generate_create_table_sql()
status = table.run_transaction([command])
assert status == True
- You may choose to replace
user_defined_columnswith a pd.DataFrame with["COLUMN", "DATA_TYPE", "SIZE"]columns.["DATABASE", "TABLE"]columns may also be passed in.
Support:
- If you have a question or need additional support, please create an issue ticket on SQLPy GitHub Repo.
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
sql_pydb-0.4.0.tar.gz
(12.2 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
sql_pydb-0.4.0-py3-none-any.whl
(12.2 kB
view details)
File details
Details for the file sql_pydb-0.4.0.tar.gz.
File metadata
- Download URL: sql_pydb-0.4.0.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
605d45bdd6c4295a02ecfae08cec52b585679a0bc7c41fdc892c57ccbf116026
|
|
| MD5 |
2047caee60302cf860c7c63f27cf95d9
|
|
| BLAKE2b-256 |
1e660ec0eaaef3b9d6b3d22f25f253bb406be91e895356054169f4a5b7b0b478
|
File details
Details for the file sql_pydb-0.4.0-py3-none-any.whl.
File metadata
- Download URL: sql_pydb-0.4.0-py3-none-any.whl
- Upload date:
- Size: 12.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2f982735e4738d924137b10f75bd33b6ca83b5f56fb7bd67e9b037114c7ddbc5
|
|
| MD5 |
6f62b95e4b25a2b15dc2aa4dcccc531e
|
|
| BLAKE2b-256 |
5cd0370dad65e5b3fa7f357dda6018e0ebd5a93e882c7676e1812ff3cb7b8199
|