0

我制作了一个小型网站,供家人和朋友猜测我们下一个孩子的姓名、性别、出生日期等。我将 vue 与 firebase 的实时数据库结合使用。现在我想用 c# 编写一个控制台应用程序来验证所有的赌注并指出一个赢家。问题是我设置数据库的方式:

-Users
    -Davy vettorato
        -posts
            -M5HuYYaUuKgqpD9qdVT
                date: "2020-09-23"
                gender: "Meisje"
                weight: "2550"
                length: "52"
                name: "Nele"
                extra_question: "11:00"
    -Dries
        -posts
            -MAerWe2LjQHGM6vEVur
                date: "21/9/2020"
                gender: "Meisje"
                weight: "4,200"
                length: "55"
                name: "Elise"
                extra_question: "11:45"
           -MAerhMgLbAe_sUyg5AE
                date: "21/9/2020"
                gender: "Jongen"
                weight: "4,200"
                length: "55"
                name: "Thibaut"
                extra_question: "11:46"

我能够获得每个用户,但后来我被卡住了。我想为从数据库派生的每个用户投注对象。这就是我已经开始的

        IFirebaseConfig config = new FirebaseConfig
        {
            AuthSecret = "//",
            BasePath = "https://babyproject-fb0.firebaseio.com/"
        };
            IFirebaseClient client = new FireSharp.FirebaseClient(config);

            if (client != null)
            {
                Console.WriteLine("Connected");
            }

            FirebaseResponse response = client.Get("");
            

            var json = response.Body;
            var result = JObject.Parse(json);

有人知道我如何获得每个用户的所有单独投注吗?我试过selectTokens,没有任何成功..

4

1 回答 1

1
 var json = response.Body;
        var result = JObject.Parse(json);

        foreach (var user in result.Children())
        {
            Better better = new Better();

            if (user is JProperty)
            {
                var prop = user as JProperty;
                better.Name = prop.Name.ToString();
                userBetList.Add(better);

                var userPosts = result[better.Name]["posts"].Children();

                foreach (var post in userPosts)
                {
                    var userPost = post as JProperty;
                    var betId = userPost.Name.ToString();
                    var betsOfId = result[better.Name]["posts"][betId].Children();
                    Bet generatedBet = new Bet();

                    foreach (var madeBet in betsOfId)
                    {
                        var bet = madeBet as JProperty;
                        if (bet.Name.ToString() == "datum")
                        {
                            generatedBet.Datum = DateTime.Parse(bet.Value.ToString());
                        }

这是我如何解决问题的示例。我认为必须有一个更简单的方法,但它完成了工作。

于 2020-09-24T18:28:04.300 回答