DatabaseException:找到两个具有冲突区分大小写的getter或字段

时间:2016-06-14 00:10:31

标签: firebase getter firebase-realtime-database case-sensitive

每当我尝试从数据库中检索数据时,我都会

com.google.firebase.database.DatabaseException: Found two getters or fields with conflicting case sensitivity for property: n

我的任何单个字母的字段。谷歌搜索这个问题给出了0个结果,我在代码中找不到任何不协调的情况。我不知道这是Firebase中的错误,还是我必须为名称长度为1的字段做一些特殊的事情。

以下是错误报告的其余部分,如果它有所不同(我引用的代码行是一个简单的

params = dataSnapshot.getValue(Parameters.class);

适用于其他任何地方:

E/AndroidRuntime: FATAL EXCEPTION: main
Process: osu.gd_prototype, PID: 11345
com.google.firebase.database.DatabaseException: Found two getters or fields with conflicting case sensitivity for property: n
at com.google.android.gms.internal.zzaix$zza.zziw(Unknown Source)
at com.google.android.gms.internal.zzaix$zza.<init>(Unknown Source)
at com.google.android.gms.internal.zzaix.zzj(Unknown Source)
at com.google.android.gms.internal.zzaix.zzd(Unknown Source)
at com.google.android.gms.internal.zzaix.zzb(Unknown Source)
at com.google.android.gms.internal.zzaix.zza(Unknown Source)
at com.google.firebase.database.DataSnapshot.getValue(Unknown Source)
at osu.gd_prototype.DataSend$1.onDataChange(DataSend.java:107)
at com.google.android.gms.internal.zzafp.zza(Unknown Source)
at com.google.android.gms.internal.zzagp.zzSu(Unknown Source)
at com.google.android.gms.internal.zzags$1.run(Unknown Source)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5001)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
at dalvik.system.NativeStart.main(Native Method)

以下是参数的代码,其中包含相关违规的getter和字段的setter,它们会引发错误:

public class Parameters {

    public int K;
    public double L;
    public int D;
    public int N;

    public Parameters() {

}

    public double getL(){
        return L;
    }
    public void setL(double lVal){
        L = lVal;
    }

    public int getK(){
        return K;
    }
    public void setK(int kVal){
        K = kVal;
    }

    public int getD(){
        return D;
    }
    public void setD(int dVal){
        D = dVal;
    }

    public int getN(){
        return N;
    }
    public void setN(int nVal){
        N = nVal;
    }
}

3 个答案:

答案 0 :(得分:16)

Firebase数据库在序列化/反序列化JSON时会考虑这些项目:

  • 公共字段
  • 类似JavaBean的属性getter / setters

由于您同时拥有公共字段NgetN() / setN()方法,因此会将两者视为冲突。虽然在这种情况下设置N并调用setN()会导致相同的结果,但情况可能并非总是如此。错误的可能性太大,这就是为什么不允许这种情况。

在这种情况下,错误消息有点像红色鲱鱼。我们应该改进这一点。

答案 1 :(得分:3)

将以下字段从公开转换为私有

public int K;
public double L;
public int D;
public int N;

private int K;
private double L;
private int D;
private int N;

答案 2 :(得分:0)

我找到了一个不同的解决方案来保留我的字段public String id,同时我还需要实现因为接口而需要实现的方法public String getId():只需使用@Exclude标记方法,例如:

public class Group implements Identifiable<String>
{
    public String id;

    protected Group ()
    {
    }

    public Group ( String id )
    {
        this.id = id;
    }

    @Exclude
    @Override
    public String getId ()
    {
        return id;
    }
}