在android中使用Sqlite作为数据库时,我们中的许多人创建一个像DbConstants这样的类,我们将所有表名、列名保存为常量。
对于 Realm DB,我们准备 POJO 类,它们分别表示为表和字段作为列名。
有什么方法可以避免在这里创建另一个常量文件吗?
用例:
POJO 代表用户表:
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;
}
}
因此,当我们查询 User 表时,如下所示:
RealmResults<User> result = realm.where(User.class)
.equalTo("name", "John")
.or()
.equalTo("name", "Peter")
.findAll();
我不想在这里使用“名称”这样的文字。那么还有其他优雅的解决方案或最佳实践吗?
通常的做法是在模型类中有一个静态最终常量,如下所示:
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
@FieldNameConstants
就是您要找的。