1

我有一个使用 ORMLite 的 Android 项目。一切正常,但对于数据库中的某些字段,它java.sql.Timestamp用作字段类型。它在我之前使用的 ORMLite 4.10 上运行良好。但是现在我需要更新 ORMLite,并且遇到了问题。当我将 ORMLite 更新到更新版本并运行它时,应用程序抛出异常:

W/System.err(  615): java.sql.SQLException: ORMLite can't store unknown class
    class java.sql.Timestamp for field 'createDate'.
    Serializable fields must specify dataType=DataType.SERIALIZABLE

之前的 createDate 字段没有 dataType 参数。但是当我添加它时,错误并没有修复,应用程序也抛出了这个异常:(。项目已经在市场上,所以我不能将 dataType 更改为其他类型(如 Date),也可以删除这个字段。

我应该在较新的 ORMLite 上使用什么作为时间戳?还是 ORMLite 错误?

更新: 通过将时间戳类型更改为可序列化类型来修复它。现在代码如下所示:

@DatabaseField(dataType = DataType.SERIALIZABLE)
public Serializable createDate;

public Timestamp getCreateDate()
{
    return (Timestamp)createDate;
}
4

1 回答 1

0

对此@st1ing 感到抱歉。这当然可能是ORMLite中的一个错误,但我怀疑它可能是不兼容的。在 4.14 版本中,我们必须更改Serializable字段的处理方式。 升级说明在线。去引用:

此外,序列化类型现在还必须指定它们的 dataType 值。您应该使用DataType.SERIALIZABLE来继续在数据库中存储序列化对象。这将允许我们在未来添加对其他序列化类型的直接支持,而不会破坏向后兼容性。

如果您已经将Serializable数据(byte[]或其他对象)存储在数据库中,那么您需要在字段中添加以下内容:

@DatabaseField(dataType = DataType.SERIALIZABLE)
Serializable field;

实际上,例外是试图给您提示如何解决您的问题:

Serializable fields must specify dataType=DataType.SERIALIZABLE

因此,请尝试将其添加到您的Timestamp领域。让我知道它是否有效。

于 2012-04-17T17:44:34.307 回答