Rey*_*eyd 1 android uid firebase firebase-realtime-database
我正在 Android Studio 中开发一个使用 Firebase 登录并将数据存储到其实时数据库的应用程序。我使用默认的 firebase 数据库规则,因此只有经过身份验证的用户才能在数据库中写入/读取。
我有一项活动 (AddMarker),它将两个 editText 值和一个 LatLong 值(来自另一活动的值)保存到数据库中。该代码实际上正在工作,我可以通过以下方式看到存储在其中的数据: 数据库结构
问题是,每次我保存(在 AddMarker Activity 中)时,链接到该 id 的先前数据都会被新数据替换。
相反,我想在数据库中存储具有相同 id 的多个值,例如:
数据库结构 2
这是我的代码
public class AddMarker extends AppCompatActivity implements View.OnClickListener {
//Save flag
public static boolean isSaved;
//Database
private DatabaseReference databaseReference;
FirebaseAuth firebaseAuth;
private FirebaseAuth mAuth;
//UI
private EditText tipo, marca;
private Button saveMarker;
public LatLng ll;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_add_marker);
//DB
mAuth = FirebaseAuth.getInstance();
databaseReference = FirebaseDatabase.getInstance().getReference();
//Initialize views
tipo = (EditText) findViewById(R.id.type);
marca = (EditText) findViewById(R.id.specInfo);
saveMarker = (Button) findViewById(R.id.save_btn);
//Initialize isSaved
isSaved = false;
//Set button listener
saveMarker.setOnClickListener(this);
//get Position
ll = getIntent().getParcelableExtra("POSITION");
}
private MarkerOptions saveMarkerInfo(){
String tipo_str = tipo.getText().toString().trim();
String marca_str = marca.getText().toString().trim();
LatLng pos = ll;
MarkerInfo markerInfo = new MarkerInfo(tipo_str,marca_str, pos);
FirebaseUser user = FirebaseAuth.getInstance().getCurrentUser();
MarkerOptions marker = new MarkerOptions()
.position(ll)
.anchor(0.0f, 1.0f)
.title("prova")
//Add data to DB
databaseReference.child(user.getUid()).setValue(markerInfo);
Toast.makeText(this,"infos saved",Toast.LENGTH_LONG).show();
finish();
return marker;
}
@Override
public void onClick(View v) {
if(v == saveMarker){
isSaved = true;
MarkerOptions mo=saveMarkerInfo();
MainActivity.mMap.addMarker(mo);
}
}
}
Run Code Online (Sandbox Code Playgroud)
小智 5
您不能创建两个具有相同 ID 的节点,而是可以在每个 userId 内创建一个嵌套结构。并相应地设置值,如下所示。
databaseReference.child(user.getUid()).push().setValue(markerInfo);
Run Code Online (Sandbox Code Playgroud)
这将使用您的多个数据在 singleUserId 下创建子项
更多你可以参考这个
| 归档时间: |
|
| 查看次数: |
8926 次 |
| 最近记录: |