java - 安卓房间Base64

标签 java android sqlite android-room

我正在尝试使用 Room 将 base64 值保存到我的 sqlite 数据库中,但由于某种原因它没有保存。好吧,我假设它没有保存,因为当我尝试读取具有 base64 列的表时,它返回除 base64 列之外的所有其他列的值。我做错了什么?

我的实体:

@Entity(tableName = "healthCareWorkerInformation",
        foreignKeys = @ForeignKey(
                entity = HealthCareWorker.class,
                parentColumns = {"id"},
                childColumns = {"hcwId"},
                onDelete = ForeignKey.CASCADE),
        indices = @Index(
                value = {"hcwId"}))
public class HealthCareWorkersInformation {
    @PrimaryKey(autoGenerate = true)
    @ColumnInfo(name = "hcwInfoId")
    private long id;
    private long hcwId;
    //@ColumnInfo(typeAffinity = ColumnInfo.BLOB)
    private String base64Image;
    private String updatedAt = new SimpleDateFormat("dd MM yyyy, HH:mm",
            Locale.getDefault()).format(Calendar.getInstance().getTime());

    public HealthCareWorkersInformation() {
    }

    @Ignore
    public HealthCareWorkersInformation(long hcwId) {
        this.hcwId = hcwId;
    }

    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    public long getHcwId() {
        return hcwId;
    }

    public void setHcwId(long hcwId) {
        this.hcwId = hcwId;
    }

    public String getBase64Image() {
        return base64Image;
    }

    public void setBase64Image(String base64Image) {
        this.base64Image = base64Image;
    }

    public String getUpdatedAt() {
        return updatedAt;
    }

    public void setUpdatedAt(String updatedAt) {
        this.updatedAt = updatedAt;
    }
}

我的 DAO:

@Insert
void insertHealthCareWorkerInformation(HealthCareWorkersInformation healthCareWorkersInformation);

@Query("SELECT * FROM HEALTHCAREWORKERINFORMATION")
LiveData<List<HealthCareWorkerInformation>> getHCWInfo();

我发送的示例数据:

{"consentGiven":null,"hcwId":1,"patiendId":1,"name":"Ben","lastName":"Ben","dateOfBirth":"4/9/2019","phoneNumber":"+271234567","base64Image":""}

除 base64 列外,其他所有内容都会被保存。请协助。

最佳答案

问题是 data:image/png;base64, 中的分号与 " 双引号结合使用。

最简单的方法是保存没有该前缀的 base64 字符串,这会破坏语法,然后假设它是所有 PNG 图像(或添加一个进一步的字段,表示每张图片的编码)。

这个问题并不特定于 Room,而是特定于使用 SQLiteJava,因为该分号终止了语句(Room 将生成)。在 Java 中,只能对原始数据类型 char 使用 ' 单引号,而对于复杂数据类型 String 除了 " 双引号。绕过此限制的唯一方法是不要尝试保存包含 ;String .

举例说明我的意思:

private String base64String = null;
private String base64Type = "png";

public String getBase64Image() {
    if(this.base64String != null) {
        return "data:image/" + this.base64Type + ";base64," + this.base64String;
    } else {
        return null;
    }
}

关于java - 安卓房间Base64,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55590307/

相关文章:

ruby-on-rails - 在现有的 Rails 应用程序上从 Sqlite3 切换到 PostgreSQL

sqlite - 在嵌入式系统/微 Controller 中运行 SQLITE 的最低硬件规范

java - 使用 super csv 通过 Java 写回 csv

java - 根据具有长值的值对映射进行排序

java - 需要一种优雅的方式在指定的时间间隔内调用任意代码

android - Android dex 中的冗余操作码

android - 避免在 CoordinatorLayout 内的 ViewPager 内的底部 View 中滚动

java - 辅助注入(inject)什么时候有用?

android - 如何在android中使用Mediaprojection库捕获屏幕并转换为mp4文件?

linux - 连续循环 SQlite3 数据库,当查询找到前 3 个运行脚本时