Run Cypher Without Leaving Your IDE With Neo4j VSCode Extension
data:image/s3,"s3://crabby-images/a6463/a6463adc2e6a7ad09ec841dd8fd38601191114fe" alt=""
Developer Experience Engineer at Neo4j
4 min read
data:image/s3,"s3://crabby-images/32ca1/32ca1347177884138c4a2b9b4b89be36ee8e601f" alt=""
How did we get here?
As a developer building Neo4j Applications in VS Code, I often switch between my code editor and other tools like Neo4j Browser when writing more complex Cypher statements. Constantly switching between the code editor and other windows to write and execute queries can take a toll on productivity. Not only does it take up a lot of time, but I also find it also disrupts my workflow and productivity. I started experimenting with custom VS Code extensions a few years ago but quickly got distracted by other things. The code sat dormant until recently when a colleague asked me what state it was in. That seeded an idea in my mind that others would really find this useful. I got talking to a few others, partly fuelled by frustration while working to a tight deadline before the holiday break, and partly motivated by the brilliant Prisma extension. I decided I had to pick this up when I returned to my desk in January.Introducing the Neo4j VS Code Extension ?
As a first release, I’ll target a few pain points that I commonly experience myself:- I often write Cypher queries in Neo4j Browser and then copy and paste the code into a Python, Node.js, or Typescript file.
- If I get something wrong in the Cypher statement, it can be difficult to identify and debug.
- Code highlighting packages for Cypher already exist but aren’t feature complete.
- I don’t like having too many windows open at once.
MATCH
,MERGE
,CREATE
, DELETE- node pattern, relationship patterns — out, in
WITH
,RETURN
SET
Installation and Usage
You can install the extension within the IDE by searching for Neo4j or the from the Visual Studio Marketplace. Once installed, you can access a list of database connections by clicking the Neo4j logo in the Activity Bar on the left-hand side.data:image/s3,"s3://crabby-images/b7846/b7846848292bdf2dee34cbe93baf5c5aa2f6ca96" alt=""
Adding a new Database Connection
You can add a database connection in three ways, all available through the Command Palette. You can configure a new connection using the Neo4j: Add Connection command.data:image/s3,"s3://crabby-images/42b8d/42b8d7cc7289b5920a7f888e5fbc43cb0c9382ac" alt=""
data:image/s3,"s3://crabby-images/3d36a/3d36a50f93d5c947b2bec2bb3cd3ba14a9196c91" alt=""
data:image/s3,"s3://crabby-images/625f0/625f0f24c1faf9bfa398f0e71143362638c8d950" alt=""
data:image/s3,"s3://crabby-images/7410c/7410cdba51a55ba4e83819d5d0766349514d84d1" alt=""
Running Cypher Queries
Once an active connection is set, you can run a Cypher statement in a read transaction using the Neo4j: Run Cypher Statement in a Read Transaction command, or write to the database using the Neo4j: Run Cypher Statement in a Write Transaction command.data:image/s3,"s3://crabby-images/52272/52272c55d2740f61710332351f72ed754787201d" alt=""
data:image/s3,"s3://crabby-images/dbe39/dbe39b3f6353333b6e21fbf896a81bb84d918ab8" alt=""
$parameters
, the extension will prompt you for the missing values.
data:image/s3,"s3://crabby-images/9e81a/9e81a9a7412405ed9478eb8ec3a3d6f727b76f36" alt=""
$parameters
, you can set them using the Neo4j: Set Parameter command. If you no longer require the parameter, you can run the Neo4j: Remove Parameter command and select the key of the parameter you want to remove.
data:image/s3,"s3://crabby-images/66e7a/66e7ab72076514d141ab8be69fe4150ec67cd312" alt=""
Bugs, Feedback & Suggestions
I would love to hear what you think about the extension. If you have any questions, comments, or feature requests you can contact me via Twitter, Mastodon, LinkedIn, or open an Issue on the Github repository. Pull requests are also welcome! Repository and Marketplace Items To learn more about Neo4j, head to Neo4j GraphAcademy for free online, hands-on, self-paced courses.Run Cypher without leaving your IDE with Neo4j VSCode extension was originally published in Neo4j Developer Blog on Medium, where people are continuing the conversation by highlighting and responding to this story.