/install ladybug-opencypher
Ladybug openCypher
Ladybug follows openCypher where possible. Schema, DDL, some clauses, and MATCH semantics differ from Neo4j. Overview: Differences between Ladybug and Neo4j. DDL: Create table.
Ladybug is embedded (in-process) — no server URI; open a file path or :memory: via real_ladybug.
Core principles
- Schema first — node and relationship tables must exist before insert. One label per node/rel table; every node table needs a primary key.
- Walk vs trail — patterns use walk semantics (edges may repeat). Use
is_trail()/is_acyclic()when you need Neo4j-like trail checks. - Variable-length paths — require an upper bound for termination; if omitted, default upper bound is 30.
- Catalog — prefer
CALL procedure(...)instead of Neo4jSHOW …for many introspection tasks.
Execute from Python (quick start)
Import real_ladybug (Ladybug Python bindings). Full docs: Python API, generated reference.
import real_ladybug as lb
db = lb.Database("path/to/db.lbug")
conn = lb.Connection(db)
rows = conn.execute("""
MATCH (a:User)-[f:Follows]->(b:User)
RETURN a.name, b.name, f.since;
""")
for row in rows:
print(row)
conn.execute/await conn.executeper statement unless the API documents batching.- Multiple statements (semicolon-separated) return a list of results; a single statement returns one result.
COPY/LOAD FROMpaths resolve relative to the process CWD unless absolute.
For async, result helpers, UDFs, and Parquet/DataFrame import — see references/api-reference.md.
Schema snippet (DDL)
CREATE NODE TABLE User(name STRING PRIMARY KEY, age INT64);
CREATE NODE TABLE City(name STRING PRIMARY KEY, population INT64);
CREATE REL TABLE Follows(FROM User TO User, since INT64);
CREATE REL TABLE LivesIn(FROM User TO City, MANY_ONE);
Optional IF NOT EXISTS. Multiplicity: MANY_ONE, ONE_MANY, MANY_MANY, ONE_ONE. CREATE NODE TABLE AS / CREATE REL TABLE AS — infer schema from LOAD FROM or MATCH … RETURN.
Import
COPY NodeTable FROM "file.csv"(Parquet and other formats per Import data).- Neo4j’s
LOAD CSV FROM→LOAD FROMin Ladybug. - In Python:
LOAD FROM df/COPY Table FROM dffor Pandas/Polars/Arrow without an intermediate file.
Full-text search (FTS)
Load the FTS extension first. Index STRING columns on node tables only; query with CALL QUERY_FTS_INDEX; list with CALL SHOW_INDEXES() RETURN *. Full procedure signatures: references/api-reference.md.
When results differ from Neo4j
Use the checklist and clause table in references/workflow-patterns.md: walk vs trail, variable-length defaults, unsupported clauses (FOREACH, REMOVE, FINISH, SET +=, …), and CALL vs SHOW.
Utility scripts
Bundled helpers (optional — require real_ladybug on PYTHONPATH):
scripts/run_cypher.py— run a Cypher string or.cypherfile against a.lbugpath.scripts/check_env.py— verifyimport real_ladybugand print basic info.
Additional resources
- Detailed Python API, FTS
CALLsyntax, and DDL/import tables: references/api-reference.md - Debugging workflows, Neo4j comparison table, query habits: references/workflow-patterns.md
Doc links
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install ladybug-opencypher - After installation, invoke the skill by name or use
/ladybug-opencypher - Provide required inputs per the skill's parameter spec and get structured output
What is ladybug-opencypher?
Runs openCypher against Ladybug DB with schema-first DDL, Python sync/async execution, CALL procedures, full-text search (CREATE_FTS_INDEX / QUERY_FTS_INDEX)... It is an AI Agent Skill for Claude Code / OpenClaw, with 142 downloads so far.
How do I install ladybug-opencypher?
Run "/install ladybug-opencypher" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is ladybug-opencypher free?
Yes, ladybug-opencypher is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does ladybug-opencypher support?
ladybug-opencypher is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created ladybug-opencypher?
It is built and maintained by Hugo (@trenza1ore); the current version is v1.0.0.