ArcadeDB Python Bindings¶
-
Production Ready
Native Python bindings for ArcadeDB with full test coverage
- Status: ✅ Production Ready
- Tests: ✅ 252 + 7 Examples Passing
-
Pure Python API
Pythonic interface to ArcadeDB's multi-model database
-
Multi-Model Database
Graph, Document, Key/Value, Vector, Time Series in one database
-
High Performance
Direct JVM integration via JPype for maximum speed
What is ArcadeDB?¶
ArcadeDB is a next-generation multi-model database that supports:
- Graph: Native property graphs with vertices and edges
- Document: Schema-less JSON documents
- Key/Value: Fast key-value pairs
- Vector: Embeddings with HNSW (JVector) similarity search
- Time Series: Temporal data with efficient indexing
- Search Engine: Full-text search with Lucene
Why Python Bindings?¶
These bindings provide native Python access to ArcadeDB's full capabilities with two access methods:
Java API (Embedded Mode)¶
- Direct JVM Integration: Run database directly in your Python process via JPype
- Best Performance: No network overhead, direct method calls
- Use Cases: Single-process applications, high-performance scenarios
- Example:
HTTP API (Server Mode)¶
- Remote Access: HTTP REST endpoints when server is running
- Multi-Language: Any language can connect via HTTP
- Use Cases: Multi-process applications, web services, remote access
- Example:
Both APIs can be used simultaneously on the same server instance.
Additional Features¶
- Multiple Query Languages: SQL, OpenCypher, MongoDB syntax
- ACID Transactions: Full transactional guarantees
- Type Safety: Pythonic API with proper error handling
Features¶
Core Features
- 🚀 Embedded Mode - Direct database access in Python process
- 🌐 Server Mode - Optional HTTP server with Studio UI
- 📦 Self-contained - All JARs and JRE bundled
- 🔄 Multi-model - Graph, Document, Key/Value, Vector
- 🔍 Multiple languages - SQL, OpenCypher, MongoDB
Advanced Features
- ⚡ High performance - Direct JVM integration via JPype
- 🔒 ACID transactions - Full transaction support
- 🎯 Vector storage - HNSW (JVector) indexing for embeddings
- 📥 Data import - CSV and ArcadeDB JSONL
- 🔎 Full-text search - Lucene integration
Quick Example¶
import arcadedb_embedded as arcadedb
# Create database (context manager for automatic open and close)
with arcadedb.create_database("./mydb") as db:
# Create schema (auto-transactional)
db.schema.create_document_type("Person")
# Insert data (requires transaction)
with db.transaction():
person = db.new_document("Person")
person.set("name", "Alice")
person.set("age", 30)
person.save()
# Query data
result = db.query("sql", "SELECT FROM Person WHERE age > 25")
for record in result:
print(f"Name: {record.get('name')}")
# db.drop() # Permanently deletes the database
Resource Management
Always use context managers (with statements) for automatic resource cleanup!
Package Coverage¶
These bindings provide comprehensive coverage of ArcadeDB's Java API, focusing on features most relevant to Python developers:
| Module | Coverage | Description |
|---|---|---|
| Core Operations | ✅ 100% | Database, queries, transactions |
| Schema Management | ✅ 100% | Types, properties, indexes |
| Server Mode | ✅ 90% | HTTP server, Studio UI, database management |
| Vector Search | ✅ 100% | HNSW (JVector) indexing, similarity search |
| Data Import | ⚠️ 70% | CSV and ArcadeDB JSONL (XML support limited, not recommended) |
| Data Export | ✅ 100% | JSONL, GraphML, GraphSON, CSV |
| Graph API | ✅ 85% | Full support via SQL and OpenCypher |
See Java API Coverage for detailed comparison.
Distribution¶
We provide a single, self-contained package that works on all major platforms:
| Platform | Package Name | Size | What's Included |
|---|---|---|---|
| All Platforms | arcadedb-embedded |
~116MB | Full ArcadeDB + Bundled JRE + Studio UI |
The package uses the standard import:
No Java Installation Required!
The package includes a bundled Java 25 Runtime Environment (JRE) optimized for ArcadeDB. You do not need to install Java separately on your system.
Getting Started¶
-
Installation instructions
-
Get up and running in 5 minutes
-
Comprehensive guide to all features
-
Detailed API documentation
Requirements¶
- Python: 3.10–3.14 (packaged; primary testing on 3.12)
- OS: Linux, macOS, or Windows (x86_64 or ARM64)
Self-Contained
Everything needed to run ArcadeDB is included in the wheel (~116MB):
- Bundled JRE (Platform-specific Java 25 runtime trimmed with jlink to only what's required for ArcadeDB, ~249MB uncompressed)
- ArcadeDB JARs (~32MB uncompressed)
- JPype (Bridge between Python and the bundled JVM)
Community & Support¶
- PyPI: arcadedb-embedded
- GitHub: humemai/arcadedb-embedded-python
- Issues: Report bugs
- ArcadeDB Docs: docs.arcadedb.com
License¶
Apache License 2.0 - see LICENSE