Skip to content

Latest commit

 

History

History
113 lines (85 loc) · 2.83 KB

README.md

File metadata and controls

113 lines (85 loc) · 2.83 KB

rexpro-client

RexPro Client for .NET

Install

To install .NET RexPro Client, run the following command in the NuGet Package Manager Console:

PM> Install-Package RexProClient

Getting started

First create a simple class to hold some vertex data.

[DataContract]
public class Example
{
    [DataMember(Name = "name")]
    public string Name { get; set; }
}

That's it. Now fire up some queries.

Queries without return value (null)

var client = new RexProClient();

client.Query("g.addVertex(['name':'foo']); null");

// same query with parameter binding
var bindings = new Dictionary<string, object> {{ "name", "foo" }};
client.Query("g.addVertex(['name':name]); null", bindings);

Queries with scalar return value

var result = client.Query<long>("g.V.count()");

Queries with complex return value

// not really different from scalar return values
var bindings = new { "name", "foo" };
var result = client.Query<Vertex<Example>>("g.addVertex(['name':name])", bindings);

Queries with sessions

using (var session = client.StartSession())
{
    client.Query("number = 1 + 2", session);
    var result = client.Query<int>("number", session);
}

Dynamic queries

var res1 = client.Query("1 + 2");
var res2 = client.Query("g.addVertex(['foo':'bar'])")
var res3 = client.Query("g.addVertex(['lorem':'ipsum']).map()")
var vertices = client.Query<dynamic[]>("g.V");
var idQuery =
    from vertex in vertices
    select vertex.Id;

Console.WriteLine("1 + 2 = {0}", res1);
Console.WriteLine("foo vertex id: {0}", res2.Id);
Console.WriteLine("lorem: {0}", res3.lorem);
Console.WriteLine("vertex ids: {0}", string.Join(",", idQuery));

Use vertex in bindings

using (var session = client.StartSession())
{
    var v1 = client.Query("g.addVertex()", session: session);
    var v2 = client.Query("g.addVertex()", session: session);
    var bindings = new Dictionary<string, object>
    {
        { "v1", v1 },
        { "v2", v2 },
        { "label", "knows" }
    };

    client.Query("g.addEdge(g.v(v1), g.v(v2), label)", bindings, session);

The previous example can also use an anonymous object instead of an dictionary.

using (var session = client.StartSession()) { var v1 = client.Query("g.addVertex()", session: session); var v2 = client.Query("g.addVertex()", session: session); var bindings = new { v1, v2, label = "knows" };

client.Query("g.addEdge(g.v(v1), g.v(v2), label)", bindings, session);

## Run unit tests
To run the unit tests, you first need to adjust the settings for your RexPro server.
In Visual Studio go to the projects application settings and customize the values for
the fields **RexProHost** and **RexProPort**.