Skip to main content

MySQL backend implementation for rhosocial-activerecord, providing a robust and optimized MySQL database support.

Project description

rhosocial-activerecord-mysql ($\rho_{\mathbf{AR}\text{-mysql}}$)

PyPI version Python Tests Coverage Status Apache 2.0 License Powered by vistart

rhosocial ActiveRecord Logo

MySQL Backend for rhosocial-activerecord

Production-Ready MySQL Support · Sync & Async · Native Driver Integration

Note: This is a backend implementation for rhosocial-activerecord. It cannot be used standalone.

Why This Backend?

1. MySQL-Specific Optimizations

Feature This Backend Generic Solutions
Full-Text Search Native MATCH ... AGAINST LIKE-based workarounds
JSON Operations JSON_EXTRACT, ->>, -> Serialize/deserialize overhead
Upsert ON DUPLICATE KEY UPDATE Manual check-then-insert
Connection Pooling Built-in with mysql-connector External pooling required

2. True Sync-Async Parity

Same API surface for both sync and async operations:

# Sync
users = User.query().where(User.c.age >= 18).all()

# Async - just add await
users = await User.query().where(User.c.age >= 18).all()

3. Built for Production

  • Connection pooling with configurable pool sizes
  • Transaction support with proper isolation levels
  • Error mapping from MySQL error codes to Python exceptions
  • Type adapters for MySQL-specific data types

Quick Start

Installation

pip install rhosocial-activerecord-mysql

Basic Usage

from rhosocial.activerecord.model import ActiveRecord
from rhosocial.activerecord.backend.impl.mysql import MySQLBackend
from rhosocial.activerecord.backend.impl.mysql.config import MySQLConnectionConfig
from typing import Optional

class User(ActiveRecord):
    __table_name__ = "users"
    id: Optional[int] = None
    name: str
    email: str

# Configure
config = MySQLConnectionConfig(
    host="localhost",
    port=3306,
    database="myapp",
    username="user",
    password="password"
)
User.configure(config, MySQLBackend)

# Use
user = User(name="Alice", email="alice@example.com")
user.save()

# Query with MySQL full-text search
results = User.query().where(
    "MATCH(name, email) AGAINST(? IN BOOLEAN MODE)",
    ("+Alice",)
).all()

💡 AI Prompt: "Show me how to use JSON operations in MySQL with this backend"

MySQL-Specific Features

Full-Text Search

Native MySQL full-text search support:

# Boolean mode full-text search
Article.query().where(
    "MATCH(title, content) AGAINST(? IN BOOLEAN MODE)",
    ("+python -java",)
).all()

# Natural language mode
Article.query().where(
    "MATCH(title, content) AGAINST(?)",
    ("database optimization",)
).all()

JSON Operations

Query JSON columns using MySQL's native JSON functions:

# Extract JSON value
User.query().where("settings->>'$.theme' = ?", ("dark",)).all()

# JSON contains
Product.query().where("JSON_CONTAINS(tags, ?)", ('"featured"',)).all()

Upsert (ON DUPLICATE KEY UPDATE)

Efficient insert-or-update operations:

# Will update on duplicate key
User.insert_or_update(
    name="Alice",
    email="alice@example.com",
    update_fields=["name"]  # Only update name on conflict
)

Requirements

  • Python: 3.8+ (including 3.13t/3.14t free-threaded builds)
  • Core: rhosocial-activerecord>=1.0.0
  • Driver: mysql-connector-python>=9.0.0

Get Started with AI Code Agents

This project supports AI-assisted development. Clone and open in your preferred tool:

git clone https://github.com/rhosocial/python-activerecord-mysql.git
cd python-activerecord-mysql

Example AI Prompts

  • "How do I configure connection pooling for MySQL?"
  • "Show me the differences between MySQL and PostgreSQL backends"
  • "How do I use MySQL-specific JSON operators?"
  • "Create a model with a FULLTEXT index"

For Any LLM

Feed the documentation files in docs/ to your preferred LLM for context-aware assistance.

Testing

⚠️ CRITICAL: Tests MUST run serially. Do NOT use pytest -n auto or parallel execution.

# Run all tests
PYTHONPATH=src pytest tests/

# Run specific feature tests
PYTHONPATH=src pytest tests/rhosocial/activerecord_mysql_test/feature/basic/
PYTHONPATH=src pytest tests/rhosocial/activerecord_mysql_test/feature/query/

See the Testing Documentation for details.

Documentation

Comparison with Other Backends

Feature MySQL PostgreSQL SQLite
Full-Text Search ✅ Native ✅ Native ⚠️ FTS5 extension
JSON Type ✅ JSON ✅ JSONB ⚠️ JSON1 extension
Arrays ✅ Native
Upsert ✅ ON DUPLICATE KEY ✅ ON CONFLICT ✅ ON CONFLICT
Returning ✅ RETURNING ✅ RETURNING

💡 AI Prompt: "When should I choose MySQL over PostgreSQL for my project?"

Contributing

We welcome contributions! See CONTRIBUTING.md for guidelines.

License

Apache License 2.0 — Copyright © 2026 vistart


Built with ❤️ by the rhosocial team

GitHub · Documentation · PyPI

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

rhosocial_activerecord_mysql-1.0.0.dev7.tar.gz (55.2 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file rhosocial_activerecord_mysql-1.0.0.dev7.tar.gz.

File metadata

File hashes

Hashes for rhosocial_activerecord_mysql-1.0.0.dev7.tar.gz
Algorithm Hash digest
SHA256 dd6d987084ba986d60ae74e14cbb17c5da9d9e2822558c8833541c1a5b0be6da
MD5 fdabbc955596f297b216c83717b89753
BLAKE2b-256 0c194606cba6a5415d82d4c6ec2bcf3d624e6afde89288bbbd642d2e5b463e5a

See more details on using hashes here.

Provenance

The following attestation bundles were made for rhosocial_activerecord_mysql-1.0.0.dev7.tar.gz:

Publisher: publish.yml on rhosocial/python-activerecord-mysql

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file rhosocial_activerecord_mysql-1.0.0.dev7-py3-none-any.whl.

File metadata

File hashes

Hashes for rhosocial_activerecord_mysql-1.0.0.dev7-py3-none-any.whl
Algorithm Hash digest
SHA256 cc1d87598a83f0fd0f7c23a627a9a2c4285074b885bea196a145ac14745d4cef
MD5 6883ef88db3c731dcaf9112065bd4d70
BLAKE2b-256 fc491dca783b3db0f62788fc724a86fbd88cededa3af879b1b9b6ea82e01b715

See more details on using hashes here.

Provenance

The following attestation bundles were made for rhosocial_activerecord_mysql-1.0.0.dev7-py3-none-any.whl:

Publisher: publish.yml on rhosocial/python-activerecord-mysql

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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