Firebase - 无法添加多个子对象

问题描述:

我制作了一个系统,负责在用户之间创建新游戏。当用户没有游戏尚未我可以添加一个没有任何问题,但是当我尝试添加第二场比赛中,我得到以下异常:Firebase - 无法添加多个子对象

异常显示java.lang.NullPointerException:尝试从外地读“ long com.skydropdesign.whoisthemost.models.Game.currentQuestion'on null object reference com.skydropdesign.whoisthemost.GameActivity $ 1.onDataChange(GameActivity.java:68) com.google.firebase.database.Query $ 1。 onDataChange() com.google.android.gms.internal.zzbpx.zza() com.google.android.gms.internal.zzbqx.zzZT() com.google.android.gms.internal.zzbra $ 1.run () android.os.Handler.handleCallback(Handler.java:739) android.os.Handler.dispatchMessage(Handler.java:95) android.os.Looper.loop(Looper.java:148) android.app。 ActivityThread.main(ActivityThread.java:7325) java.lang.reflect.Method.invoke(Method.java) com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:1230) com.android .internal.os.ZygoteInit.main(ZygoteInit.java:1120)

如此看来,错误被抛出,因为GameActivity类无法检索数据,因为这是不保存的某些原因。当我还没有比赛时,情况就不一样了。

创建一个游戏的代码是:

package com.skydropdesign.whoisthemost; 

import android.app.ProgressDialog; 
import android.content.Intent; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.View; 
import android.widget.Button; 
import android.widget.EditText; 
import android.widget.Toast; 

import com.google.firebase.database.DataSnapshot; 
import com.google.firebase.database.DatabaseError; 
import com.google.firebase.database.Query; 
import com.google.firebase.database.ValueEventListener; 
import com.skydropdesign.whoisthemost.models.Game; 

import java.util.Random; 

public class AddGameActivity extends BaseActivity implements View.OnClickListener { 
protected String username; 
protected String opponentId; 
protected ProgressDialog dialog; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_new_game); 

    Button playButton = (Button) findViewById(R.id.play_button); 
    playButton.setOnClickListener(this); 
} 

@Override 
public void onClick(View v) { 
    if(v.getId() == R.id.play_button) { 
     EditText editText = (EditText) findViewById(R.id.player_username); 
     username = editText.getText().toString().trim().toLowerCase(); 

     dialog = new ProgressDialog(this); 
     dialog.setTitle("Loading"); 
     dialog.setCancelable(false); 

     Query query = database.getReference("users").orderByChild("username").equalTo(username); 
     query.addListenerForSingleValueEvent(new ValueEventListener() { 
      @Override 
      public void onDataChange(DataSnapshot dataSnapshot) { 
       if(dataSnapshot.exists()) { 

        for(DataSnapshot gameSnapshot : dataSnapshot.getChildren()) { 
         opponentId = gameSnapshot.getKey(); 

         Query query1 = database.getReference("games").child(user.getUid()); 
         query1.addListenerForSingleValueEvent(new ValueEventListener() { 
          @Override 
          public void onDataChange(DataSnapshot dataSnapshot) { 
           if (!dataSnapshot.exists()) { 
            Random rn = new Random(); 
            long chosenQuestion = rn.nextInt(getResources().getStringArray(R.array.questions).length); 

            database.getReference("games").child(user.getUid()).child(opponentId).setValue(
              new Game(chosenQuestion, -1, true) 
            ); 
            database.getReference("games").child(opponentId).child(user.getUid()).setValue(
              new Game(chosenQuestion, -1, false) 
            ); 
           } 

           dialog.dismiss(); 
           Intent gameIntent = new Intent(AddGameActivity.this, GameActivity.class); 
           gameIntent.putExtra("gameId", opponentId); 
           //startActivity(gameIntent); 
           finish(); 
          } 

          @Override 
          public void onCancelled(DatabaseError databaseError) { 

          } 
         }); 
        } 

       } else { 
        Toast.makeText(AddGameActivity.this, "That username does not exist", Toast.LENGTH_SHORT).show(); 
       } 
      } 

      @Override 
      public void onCancelled(DatabaseError databaseError) { 

      } 
     }); 
    } 
} 

}

我的数据库结构如下:

  • 游戏
    • $用户id
      • $ opponentId
        • currentQuestion(长)
        • currentAnswer(长)
        • canAnswer(布尔)
  • 用户
    • $用户id
      • 显示名(串)
      • 电子邮件(串)
      • 的用户名(字符串)

对于每一个新的游戏,我想一个游戏对象添加到游戏/ $身份识别码/ $ opponentId和游戏/ $ opponentId/$ myId的对手。

我希望你能告诉我我在这里做错了什么,以及我如何解决这个错误。

+0

如果你有多个孩子,我建议使用reference.updateChildren(地图)来更新它们。 – JacksOnF1re

addListenerForSingleValueEvent用于读取来自Firebase数据库的数据。

如果要写入数据,那么你可以参考下面的代码:

private DatabaseReference mDatabase; 
mDatabase = FirebaseDatabase.getInstance().getReference(); 

mDatabase.child("games").child($userId).setValue(user_id); 

你可以参考this链接来阅读和火力地堡数据库写入数据。