Skip to main content

This package provides a simple model structure for redis based storage.

Project description

Redis Models

This package provides a simple model structure for redis based storage. It acts like an ORM and allows you to create models with validation.

Installation

pip install redis_models

Usage

First, you need to create your model. It's similar to Pydantic models, or built-in dataclass.

from redis_models.models import RedisModel


class MyUserModel(RedisModel):
    name: str
    age: int

    class Meta:
        redis_url = "redis://localhost:6379/0"
        indexes = ("name", )

Let's create a User object

user = User(name="John Doe", age=30)

Let's try creating an object that does not fit to the definition

try:
    bad_user = User(name="John", eye_color="blue")
except ValidationError:
    pass

Let's write it to Redis

user.save()

Let's see its id. ids are UUID4 hex strings

print(user.id)

Fetch the record from Redis

user_again = User.get(id=user.id)

See the object as dictionary

print(user.asd)

Let's delete the record

user_again.delete()

Trying to find a non-existing record throws NotFound exception

from redis_models.errors import NotFound

try:
    user_not_found = User.get(id=user_again.id)
except NotFound:
    print("User not found!")

Trying to filter with exact values. In this example, name field is noted as an index in the model.

User.filter(name="nejdet")  # Returns a list of dictionaries

How it works

This package relies on RedisModelMeta and RedisModel classes. RedisModelMeta is a type constructor and RedisModel is a class that contains required methods for derived models.

When you call YourModel.save() the method will

  • Run YourModel.asdict() and get the whole data serialized to JSON (Therefore each field must be JSON-serializable!)

  • Create a key like YourModel-data-<SOME_UUID> and puts the whole serialized data as value

  • Create an index set for each field you put in YourModel.Meta.indexes using YourModel-index-<INDEX_FIELD_NAME>-<INDEX_FIELD_VALUE> format and UUID for each record as a value.

When you call YourModel.get(id=id_value) the method will search among YourModel-data-<SOME_UUID> keys and return the data.

When you call YourModel.filter(index1=value1, index2=value2) the method will

  • Use SINTER to have an intersection for UUIDs.
  • Then uses MGET to get multiple values at once.
  • Returns a generator that yields YourModel objects (for memory efficiency).

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

redis_models-0.4.0.tar.gz (4.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

redis_models-0.4.0-py2.py3-none-any.whl (4.9 kB view details)

Uploaded Python 2Python 3

File details

Details for the file redis_models-0.4.0.tar.gz.

File metadata

  • Download URL: redis_models-0.4.0.tar.gz
  • Upload date:
  • Size: 4.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.3

File hashes

Hashes for redis_models-0.4.0.tar.gz
Algorithm Hash digest
SHA256 14683ffa17f5c27212046262633e0334b0c3c57c7d3547003439e8c23107174c
MD5 8270726e721e09d624b75d795d0deec2
BLAKE2b-256 c920d9e61b01df5e1af237bc330945b000556dc9318e3745be7105354c2fee00

See more details on using hashes here.

File details

Details for the file redis_models-0.4.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for redis_models-0.4.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 d78045898ece07836cb3db8daca69219f172792165baee8978e7ab825ae444d5
MD5 26ab560e3aa999479fe4447f9018dfde
BLAKE2b-256 95fda24e4e9ef9b9238245d7580188bc7d7e62a0fddfeaf2762b0415ec5aeff7

See more details on using hashes here.

Supported by

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