1

在 ASP.NET Core 编程中建立与 Neo4j DB 的连接的普通方法是什么?

Neo4j 语言指南 ( https://neo4j.com/developer/language-guides/ ) 中的代码适用于简单的控制台应用程序,但它没有解释如何在 ASP.NET 中编码,所以我只是复制和粘贴MVC脚手架的代码:

  public class TestController : Controller
  {
    public TestController()
    {
      _driver = GraphDatabase.Driver("bolt://localhost"));
    }
    private readonly IDriver _driver;
    public string Index()
    {
      using (var session = _driver.Session())
      {
        var greeting = session.WriteTransaction(tx =>
        {
          var result = tx.Run("CREATE (a:Greeting) " +
                              "SET a.message = $message " +
                              "RETURN a.message + ', from node ' + id(a)",
                       new { message });
          return result.Single()[0].As<string>();
        });
        return greeting;
      }
    }
  }

工作正常,但为每个请求调用 GraphDratabase.Driver() 似乎没有意义。

它不应该注册到服务吗?(Startup.cs 中的 AddSingleton()?)

如果是这样,我如何从控制器访问驱动程序?

4

1 回答 1

1

将其注册到服务似乎是一个好主意。你可以这样做:

    public void ConfigureServices(IServiceCollection services)
    {
        services.AddMvc();

        services.AddSingleton(GraphDatabase.Driver("bolt://localhost"));
    }

然后将其注入控制器:

public TestController(IDriver driver)
{
  _driver = driver;
}
于 2018-07-15T19:07:09.593 回答