🐞 ladybug-opencypher — Ladybug数据库openCypher查询
v1.0.0在Ladybug本地数据库上运行openCypher查询的技能,支持schema优先的DDL定义、Python同步/异步执行、CALL存储过程和全文搜索(FTS)扩展,适用于图数据库查询调试和数据导入场景。
详细分析 ▾
运行时依赖
版本
ladybug-opencypher初始版本发布。支持在Ladybug数据库上运行openCypher查询,具备schema优先的DDL支持。支持Python(同步/异步)执行、CALL存储过程和全文搜索扩展(FTS)。突出介绍了与Neo4j Cypher的关键差异,包括schema、DDL和模式语义。包含用于查询执行和环境检查的实用脚本。提供了Cypher功能、DDL、导入、FTS和Neo4j迁移说明的文档链接。
安装命令 点击复制
技能文档
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 lbdb = 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
免费技能或插件可能存在安全风险,如需更匹配、更安全的方案,建议联系付费定制