android - 将空值加载到原始类型中

标签 android ormlite

我正在尝试使用 ormlite 查询方法将数据库行加载到 DO 对象中。我面临的问题是数据库中的空值映射到 DO 对象中的 Wrapper 类型字段。空字段作为 0 填充到 DO 中,这打乱了我的业务逻辑。

有什么方法可以使 ormlite 将这些字段填充为 null 而不是 0。

我的示例 DO 结构:

@DatabaseTable(tableName="PERSON")
public class Person
{
   @DatabaseField(columnName="NAME", dataType=DataType.STRING, useGetSet=true)
   private String name;

   @DatabaseField(columnName = "AGE", dataType = DataType.SHORT, useGetSet = true)
   private Short age;

   public String getName() 
   {
      return name;
   }

   public void setName(String name) 
   {
      this.name = name;
   }

   public Short getAge() 
   {
     return age;
   }

   public void setAge(Short age) 
   {
     this.age = age;
   }
}

我用来加载对象的 DAO 代码是:

person = queryForEq("NAME", someName).get(0);

总而言之,在 Person 类中,如果人员的年龄在 SQLite 数据库中存储为 null,则 ormlite 在查询对象时填充为 0。我想避免这种情况并确保年龄设置为空。有什么办法可以实现吗?

最佳答案

此处正确的做法是不要将 dataType 指定为 @DatabaseField 注释的一部分。 ORMLite然后将正确使用 DataType.SHORT_OBJ 字段类型。由于您要覆盖默认字段类型并说 Short 字段实际上是原始字段,如果 ORMLite did 为其分配空值,则会导致 NPE,因此它分配0 代替。您的数据对象应该是:

@DatabaseField(columnName="NAME", useGetSet=true)
private String name;

@DatabaseField(columnName = "AGE", useGetSet = true)
private Short age;

实际上,您永远不需要指定 dataType,除非您正在覆盖某些内容,或者如果 ORMLite 无法做出良好的自动类型确定(例如:byte[])。

关于android - 将空值加载到原始类型中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9260761/

相关文章:

Android WebView显示全高清html

android - OrmLite 和 proguard 混淆的问题

android - ORMlite Android 外键支持

android - 如何将原始类型(String)的集合存储到数据库中

android - 如何在 ORMLite 中使用不同的外键?

android - 替代 Google maps V2 for Android 中的 ItemizedOverlay?

java - 排序和比较两个列表的最短方法

android - Android Kotlin中的自定义Alertdialog

android - Allocation.copyTo(Bitmap) 破坏像素值

ormlite - 使用 ORMLite 编写查询