为字段名称维护单独常量的替代方法

Alternative for maintaining separate constants for field names

在 android 中使用 Sqlite 作为数据库时,我们中的许多人创建了一个 class 之类的 DbConstants,我们将所有 Table 名称、列名称保存为常量。

对于 Realm DB,我们准备了 POJO classes,它们分别表示为 tables 和字段作为列名。

有什么方法可以避免在这里创建另一个常量文件吗?

用例:

代表用户的 POJO table :

public class User extends RealmObject {

private String          name;
private int             age;

@Ignore
private int             sessionId;

// Standard getters & setters generated by your IDE…
public String getName() { return name; }
public void   setName(String name) { this.name = name; }
public int    getAge() { return age; }
public void   setAge(int age) { this.age = age; }
public int    getSessionId() { return sessionId; }
public void   setSessionId(int sessionId) { this.sessionId = sessionId;       
 }
}

所以当我们按如下方式查询用户 table 时:

RealmResults<User> result = realm.where(User.class)
                              .equalTo("name", "John")
                              .or()
                              .equalTo("name", "Peter")
                              .findAll();

我不想在这里使用像“name”这样的文字。那么还有其他优雅的解决方案或最佳实践吗?

通常的做法是在你的模型中有一个静态的最终常量 class 像这样:

public class User extends RealmObject {
  public static final String NAME = "name";
  public static final String AGE = "age";

  // Fields, constructors, getters, setters,
}

realm.where(Person.class).equalTo(Person.NAME, "John").findAll();

如果你想要一种自动化的方式,你可以看看:https://github.com/cmelchior/realmfieldnameshelper