Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/prodbygodfather/abarorm
abarorm is a lightweight and easy-to-use Object-Relational Mapping (ORM) library for SQLite, MySQL, and PostgreSQL databases in Python. It provides a simple and intuitive interface for managing database models and interactions.
https://github.com/prodbygodfather/abarorm
mysql-orm orm postgresql-orm python-orm sqlite-orm
Last synced: about 2 months ago
JSON representation
abarorm is a lightweight and easy-to-use Object-Relational Mapping (ORM) library for SQLite, MySQL, and PostgreSQL databases in Python. It provides a simple and intuitive interface for managing database models and interactions.
- Host: GitHub
- URL: https://github.com/prodbygodfather/abarorm
- Owner: ProdByGodfather
- License: apache-2.0
- Created: 2024-08-17T12:33:10.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-11-12T05:58:38.000Z (2 months ago)
- Last Synced: 2024-11-12T06:27:35.305Z (2 months ago)
- Topics: mysql-orm, orm, postgresql-orm, python-orm, sqlite-orm
- Language: Python
- Homepage: https://prodbygodfather.github.io/abarorm/
- Size: 1.82 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# abarorm
| ![abarorm Logo](https://prodbygodfather.github.io/abarorm/images/logo.png) | **abarorm** is a lightweight and easy-to-use Object-Relational Mapping (ORM) library for SQLite, MySQL, and PostgreSQL databases in Python. It provides a simple and intuitive interface for managing database models and interactions. |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|## Features
- Define models using Python classes.
- Automatically handle database schema creation and management.
- Support for basic CRUD (Create, Read, Update, Delete) operations.
- Manage foreign key relationships effortlessly.
- Custom field types with validation and constraints.
- **New in v1.0.0**: Automatic table creation and updates without needing explicit `create_table()` calls.
- **New in v2.0.0**: Added support for PostgreSQL databases.
- **New in v2.0.0**: Ordering by fields in the `all()` method.
- **New in v3.0.0**: Fixed table naming bugs to ensure consistent naming conventions.
- **New in v3.0.0**: Updated return values for methods to improve clarity and usability.
- **New in v3.0.0**: Enhanced `filter` method now supports `order_by` functionality for result ordering.
- **New in v3.2.0**: Added `__gte` and `__lte` functionality in the filter section.## Installation
You can install [**abarorm**](https://pypi.org/project/abarorm/) from PyPI using pip:
```bash
pip install abarorm
```
For MySQL support, you also need to install `mysql-connector-python`:```bash
pip install mysql-connector-python
```
For PostgreSQL support, you need to install `psycopg2-binary`:
```bash
pip install psycopg2-binary
```## Documentation
For detailed documentation, examples, and advanced usage, please visit the [official abarorm documentation website](https://prodbygodfather.github.io/abarorm/).## Database Configuration
Before defining models, you need to set up your database configuration. This involves specifying connection parameters for the database you are using (SQLite, MySQL, or PostgreSQL). Here’s an example of how to configure the database:
```python
# Database configuration
DATABASE_CONFIG = {
'sqlite': {
'db_name': 'example.db', # Name of the SQLite database file
},
'mysql': {
'host': 'localhost',
'user': 'your_mysql_user',
'password': 'your_mysql_password',
'database': 'example_db',
},
'postgresql': {
'host': 'localhost',
'user': 'your_pg_user',
'password': 'your_pg_password',
'database': 'example_db',
}
}
```
## Model Definition
After setting up the database configuration, you can define your models. A model is a representation of a database table. Here’s how to create a model using abarorm:
```python
from abarorm import SQLiteModel, MySQLModel, PostgreSQLModel
from abarorm.fields import CharField, DateTimeField, ForeignKey# Define the Category model for SQLite
class Category(SQLiteModel):
class Meta:
db_config = DATABASE_CONFIG['sqlite']
table_name = 'categories' # Name of the table for storing the Category model datatitle = CharField(max_length=200, null=False) # Title of the category, must be unique and not null
create_time = DateTimeField(auto_now=True, auto_now_add=True) # Automatically set to current datetime
update_time = DateTimeField(auto_now=True) # Automatically set to current datetime# Define the Post model for MySQL
class Post(MySQLModel):
class Meta:
db_config = DATABASE_CONFIG['mysql']title = CharField(max_length=100, null=False) # Title of the post, must be unique and not null
create_time = DateTimeField(auto_now=True) # Automatically set to current datetime
category = ForeignKey(to=Category) # Foreign key referring to the Category model
```
## CRUD Operations
Now that you have defined your models, you can perform CRUD operations. Here’s a breakdown of each operation:
### Create
To create new records in the database, use the `create()` method. For example:
```python
# Create a new category
Category.create(title='Movies')# Create a new post
category = Category.get(id=1) # Fetch the category with ID 1
if category:
Post.create(title='Godfather', category=category.id) # Create a new post associated with the fetched category
```
### Read
To read records from the database, use the `all()` or `get()` methods:
```python
# Retrieve all posts
all_posts = Post.all()# Retrieve a specific post by ID
post_data = Post.get(id=1)
```
### Filtering Records
The `filter()` method allows you to retrieve records based on specified criteria. You can use keyword arguments to filter by field values and sort the results using `order_by`.
```python
# Filter posts by category ID and order by creation time
filtered_posts = Post.filter(category=category.id, order_by='-create_time')
```
#### Advanced Filtering
You can also use special lookup expressions like `__gte` (greater than or equal to) and `__lte` (less than or equal to) for more complex queries:
```python
# Retrieve posts created after a specific date
filtered_posts = Post.filter(create_time__gte='2024-01-01 00:00:00')
```### Update
To update existing records, fetch the record, modify its attributes, and then save it:
```python
if post_data:
post_data.title = "The Godfather"
post_data.save() # Save the updated post data
```
Or:
```python
Post.update(1, title='Updated Godfather') # Update the title of the post with ID 1 to 'Updated Godfather'
```
### Delete
To delete a record from the database, use the `delete()` method:
```python
Post.delete(1) # Delete the post with ID 1
```### Version 3.0.0
- **Fixed Table Naming**: Resolved issues related to inconsistent table naming conventions.
- **Return Values Updated**: Methods now return values that enhance clarity and usability.
- **Filter Enhancements**: The `filter` method now includes support for `order_by`, allowing for more flexible queries.**Important for Developers:** When adding new fields to models, they will default to `NULL`. It’s recommended to recreate the database schema after development is complete to ensure fields have appropriate constraints and default values.
## Contributing
Contributions are welcome! If you find any issues or have suggestions for improvements, please open an issue or submit a pull request on GitHub.
## License
This project is licensed under the [Apache-2.0 License](https://github.com/ProdByGodfather/abarorm/blob/main/LICENSE) - see the LICENSE file for details.
## Acknowledgements
- **Python**: The language used for this project.
- **SQLite & MySQL**: The databases supported by this project.
- **setuptools**: The tool used for packaging and distributing the library.
- **psycopg2-binary**: The PostgreSQL adapter used for connecting to PostgreSQL databases.