Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/carlos-rian/pysqlx-core
A fast and async SQL database wrapper for Python, with support for MySQL, PostgreSQL, SQLite and MS SQL Server.
https://github.com/carlos-rian/pysqlx-core
anyio asyncio mssqlserver mysql postgresql python quaint rust sql sqlite3
Last synced: 5 days ago
JSON representation
A fast and async SQL database wrapper for Python, with support for MySQL, PostgreSQL, SQLite and MS SQL Server.
- Host: GitHub
- URL: https://github.com/carlos-rian/pysqlx-core
- Owner: carlos-rian
- License: mit
- Created: 2022-07-23T19:07:51.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-10-30T16:28:00.000Z (over 1 year ago)
- Last Synced: 2024-04-25T00:55:51.396Z (10 months ago)
- Topics: anyio, asyncio, mssqlserver, mysql, postgresql, python, quaint, rust, sql, sqlite3
- Language: Rust
- Homepage:
- Size: 493 KB
- Stars: 6
- Watchers: 2
- Forks: 0
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- jimsghstars - carlos-rian/pysqlx-core - A fast and async SQL database wrapper for Python, with support for MySQL, PostgreSQL, SQLite and MS SQL Server. (Rust)
README
# __pysqlx-core__
[](https://github.com/carlos-rian/pysqlx-core/actions?query=event%3Apush+branch%3Amain+workflow%3Aci)
[](https://pypi.python.org/pypi/pysqlx-core)
[](https://github.com/carlos-rian/pysqlx-core)
[](https://github.com/carlos-rian/pysqlx-core/blob/main/LICENSE)
[](https://pepy.tech/project/pysqlx-core)pysqlx-core is an extremely fast Python library for communicating with various SQL databases.
This package provides the core functionality for [__PySQLX-Engine__](https://carlos-rian.github.io/pysqlx-engine/).
The package is currently a work in progress and subject to significant change.
[__pysqlx-core__](https://pypi.org/project/pysqlx-core/) will be a separate package, required by [__pysqlx-engine__](https://carlos-rian.github.io/pysqlx-engine/).
This package is written entirely in Rust and compiled as a Python library using PyO3 and PyO3-Asyncio.
This core is not so friendly, but maybe you want to use it, feel free to suggest improvements.
### Supported databases
* [__`SQLite`__](https://www.sqlite.org/index.html)
* [__`PostgreSQL`__](https://www.postgresql.org/)
* [__`MySQL`__](https://www.mysql.com/)
* [__`Microsoft SQL Server`__](https://www.microsoft.com/sql-server)### Supported Python versions
* [__`Python >= 3.8`__](https://www.python.org/)
### Supported operating systems
* [__`Linux`__](https://pt.wikipedia.org/wiki/Linux)
* [__`MacOS`__](https://pt.wikipedia.org/wiki/Macos)
* [__`Windows`__](https://pt.wikipedia.org/wiki/Microsoft_Windows)### Example of installation:
__PIP__
```bash
$ pip install pysqlx-core
```__Poetry__
```bash
$ poetry add pysqlx-core
```### Example of usage:
```python
import pysqlx_core
import asyncioasync def main(sql):
# Create a connection
db = await pysqlx_core.new(uri="postgresql://postgres:postgrespw@localhost:49153")
# Create a table
stmt = pysqlx_core.PySQLxStatement(
provider="postgresql",
sql="""
CREATE TABLE IF NOT EXISTS test (
id SERIAL PRIMARY KEY,
name VARCHAR(255) NOT NULL
);
""")
await db.execute(stmt=stmt)# Insert a row and return quantity rows affected
insert = pysqlx_core.PySQLxStatement(
provider="postgresql",
sql="INSERT INTO test (name) VALUES (:name);",
params={"name": "Carlos"}
)
await db.execute(stmt=insert)# can you see the sql and params pre builded
print("SQL:", insert.sql())
# output: INSERT INTO test (name) VALUES ($1);
print("PARAMS:", insert.params())
# output: ['Carlos']# Select all rows, return a class PySQLxResponse
result = await db.query_typed(stmt=pysqlx_core.PySQLxStatement(
provider="postgresql",
sql="SELECT * FROM test;"
)
)
# get first row
row = result.get_first() # Dict[str, Any]
# get all rows
rows = result.get_all() # List[Dict[str, Any]]
# return the db 'types' to Pydantic BaseModel
types = result.get_types() # Dict[str, str]# Select all rows, return how List[Dict[str, Any]]
rows = await db.query_all(pysqlx_core.PySQLxStatement(provider="postgresql", sql="SELECT * FROM test;"))# close? no need 👌-> auto-close when finished programmer or go out of context..
asyncio.run(main())
```