簡體   English   中英

如何使用C#從neo4j數據庫獲取數據並將其綁定到網格視圖中?

[英]How to get data from neo4j database and bind it into a grid view using C#?

我用C#編寫了這個密碼查詢:

var myClint = new GraphClient(new Uri("http://localhost:7474/db/data"), "neo4j", "1412");
 myClint.Connect();

 var getName= myClint.Cypher.Match("(n:Person)
                      .Return(n => n.As<Person>())
                      .Results;

我在Person類中有setter和getter來為Person節點中的每個人獲取名稱,ssn和年齡。 我想在網格視圖上顯示這些信息。 我用sql server做到了,但是我不知道如何用neo4j做到這一點。

提前致謝

https://stackoverflow.com/users/6771545/abd

本質上,您需要創建自己的DataTable ,您可以使用以下代碼手動進行操作:

public static DataTable ConvertToTable(IEnumerable<Person> people)
{
    DataTable dt = new DataTable();
    dt.Columns.Add("Name");
    dt.Columns.Add("Age");

    foreach (var person in people)
    {
        var row = dt.NewRow();
        row[0] = person.Name;
        row[1] = person.Age;
        dt.Rows.Add(row);
    }

    return dt;
}

但這意味着您必須為每種類型編寫其中之一,因此您可以改為:

public static DataTable ConvertToTableAutomatic<T>(IEnumerable<T> items)
{
    DataTable dt = new DataTable();

    var properties = typeof(T).GetProperties();
    foreach (var property in properties)
        dt.Columns.Add(property.Name);

    foreach (var item in items)
        dt.Rows.Add(FillRow<T>(dt.NewRow(), item, properties));

    return dt;
}

private static DataRow FillRow<T>(DataRow row, T item, PropertyInfo[] properties)
{
    foreach (var property in properties)
        row[property.Name] = property.GetValue(item);

    return row;
}

但是請記住-您將無法使用此更新Neo4j DB,僅顯示信息。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM