Stored Procedures¶
Stored procedures in GraphScope Interactive offer a powerful way to encapsulate and reuse complex graph operations. This document provides a guide on how to compile, enable, and manage these procedures. We will take movies graph for example.
Note
Before executing the following code, please ensure that you are in the context of the builtin graph gs_interactive_default_graph
: gsctl use GRAPH gs_interactive_default_graph
.
Define a Stored Procedure¶
To compile a stored procedure, first define it with a YAML file named procedure.yaml
, which defines a stored procedure that searches for softwares
created by the person with the provided name. The person’s name has been parameterized as $personName
.
name: test_procedure
description: "Ths is a test procedure"
query: 'MATCH (p: person)-[c:created]->(s: software) where p.name = $personName RETURN s.id as softwareId, s.name as softwareName;'
type: cypher
Note:
name
is required.description
is optional.The string in
query
field could be eithercypher
query orc++
code. For comprehensive guidelines on crafting stored procedures in GraphScope Interactive using both Cypher and C++, refer to the Cypher procedure and C++ procedure documentation.When compiling from Cypher code, the optimization rules defined under
compiler.planner
will be taken into account to generate a more efficient program.
For more information on defining a Cypher stored procedure, please refer to Cypher Stored Procedure.
Create a Stored Procedure¶
Then create the procedure with gsctl
:
gsctl create storedproc -f ./procedure.yaml
This will invoke the compilation procedure to convert the cypher query to a physical plan, then generate C++ code and compile it, so it may take some time.
Restart the service is necessary to activate the stored procedures:
gsctl service restart
Delete a Stored Procedures¶
To delete a single stored procedures, simply using:
gsctl delete storedproc test_procedure
Viewing Stored Procedures¶
To view a single stored procedure,
gsctl desc storedproc test_procedure
Or, show all valid procedures in cypher shell.
@neo4j> Show Procedures;
Querying Stored Procedures¶
Call the Stored Procedure via Interactive SDK¶
You can call the stored procedure via Interactive Python SDK. (Make sure environment variables are set correctly, see Deploy Interactive).
export INTERACTIVE_ADMIN_ENDPOINT=http://127.0.0.1:7777
export INTERACTIVE_STORED_PROC_ENDPOINT=http://127.0.0.1:10000
export INTERACTIVE_CYPHER_ENDPOINT=neo4j://127.0.0.1:7687
Note
If you have customized the ports when deploying Interactive, remember to replace the default ports with your customized ports.
from gs_interactive.client.driver import Driver
from gs_interactive.client.session import Session
from gs_interactive.models import *
driver = Driver()
with driver.getNeo4jSession() as session:
result = session.run('CALL test_procedure("marko") YIELD *;')
for record in result:
print(record)
Call the Stored Procedure via Neo4j-native Tools¶
You can also call the stored procedure via neo4j-native tools, like cypher-shell
, neo4j-driver
. Please refer to this document for connecting to cypher service.
./cypher-shell -a ${INTERACTIVE_CYPHER_ENDPOINT}
CALL test_procedure("marko") YIELD *;