java - 在 Firebase 数据库的情况下,变量名称如何转换为文本以创建子节点?
问题描述
我正在使用以下 Android 代码,它工作正常,没有问题,但我有一个问题。
变量名称(例如:名称、课程、持续时间)如何转换为文本以创建节点,如下图所示:
XML 代码:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center_horizontal"
android:orientation="vertical"
tools:context=".MainActivity">
<!-- android:id="@+id/btn"-->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="process"
android:text="save to database"
android:textSize="25dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.491"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.66"
tools:ignore="MissingConstraints,OnClick" />
<EditText
android:id="@+id/t2"
android:layout_width="300dp"
android:layout_height="wrap_content"
android:hint="enter your name"
android:textColor="#000"
android:textSize="25dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.495"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.172"
tools:ignore="MissingConstraints" />
<EditText
android:id="@+id/t3"
android:layout_width="300dp"
android:layout_height="wrap_content"
android:hint="enter your course"
android:textColor="#000"
android:textSize="25dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.522"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.298"
tools:ignore="MissingConstraints" />
<EditText
android:id="@+id/t4"
android:layout_width="300dp"
android:layout_height="wrap_content"
android:hint="enter your duration"
android:textColor="#000"
android:textSize="25dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.504"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.429"
tools:ignore="MissingConstraints" />
<EditText
android:id="@+id/t1"
android:layout_width="300dp"
android:layout_height="wrap_content"
android:hint="enter your roll number"
android:textColor="#000"
android:textSize="25dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.495"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.041"
tools:ignore="MissingConstraints" />
</androidx.constraintlayout.widget.ConstraintLayout>
MainActivity.java 的代码:
package com.example.application_for_curd;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
public class MainActivity extends AppCompatActivity {
EditText t1,t2,t3,t4;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void process(View v){
t1 = findViewById(R.id.t1);
t2 = findViewById(R.id.t2);
t3 = findViewById(R.id.t3);
t4 = findViewById(R.id.t4);
String roll = t1.getText().toString().trim();
String name = t2.getText().toString().trim();
String course = t3.getText().toString().trim();
String duration = t4.getText().toString().trim();
dataholder obj = new dataholder(name,course,duration);
FirebaseDatabase db = FirebaseDatabase.getInstance();
DatabaseReference node = db.getReference("students");
node.child(roll).setValue(obj);
t1.setText("");
t2.setText("");
t3.setText("");
t4.setText("");
Toast.makeText(getApplicationContext(),"values inserted", Toast.LENGTH_LONG).show();
}
}
dataholder.java 的代码:
package com.example.application_for_curd;
public class dataholder {
String name,course,duration;
public dataholder(String name, String course, String duration) {
this.name = name;
this.course = course;
this.duration = duration;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getCourse() {
return course;
}
public void setCourse(String course) {
this.course = course;
}
public String getDuration() {
return duration;
}
public void setDuration(String duration) {
this.duration = duration;
}
}
变量名称将如何转换为创建子节点的文本,可以通过附加图像看到,该图像由名为名称、课程、持续时间的子节点组成。
解决方案
根据您的最后评论:
但是名称,当然,持续时间这些是不是字符串的字符串变量
我了解您希望根据字段的相应数据类型在数据库中包含字段值。“名称”和“课程”对于字符串类型是有意义的,但是,“持续时间”应该作为数字添加。您可以将两种不同类型的值保存到 number 类型的属性中,即“long”值和“double”值。为此,您应该将“dataholder”类中的属性类型更改为例如“long”类型,而不是String。相同的规则适用于双精度值的情况。所以你应该有以下声明:
private String name, course;
private long duration;
这是相应的getter和setter:
public long getDuration() {
return duration;
}
public void setDuration(long duration) {
this.duration = duration;
}
你的构造函数应该是这样的:
public dataholder(String name, String course, long duration) {
this.name = name;
this.course = course;
this.duration = duration;
}
现在要将“duration”的值保存为数字而不是字符串,请更改以下代码行:
String duration = t4.getText().toString().trim();
至:
long duration = Long.parseLong(t4.getText().toString().trim());
通过这些更改,不再允许像“2 年”这样的值,因为它是字符串而不是数字。因此请注意更改数据库中的所有“持续时间”属性以保存数字而不是字符串值。