2

问题:我无法使用 greenDao 将没有 id 的 gson 创建对象插入数据库

设置绿道

我的网络服务返回这样的输出

[
    {
        id: 2,
        firstName: "John",
        lastName: "Cleese",
        dateOfBirth: -952473600,
        profession: {
            name: "Actor",
            description: "TV show entertainer"
        }
    }
]

Gson把它变成一个有Person对象的Profession对象。这些类使用GreenDao Generator.

Schema schema = new Schema(SCHEMA_VERSION, "com.example.dao");

Entity profession = schema.addEntity("Profession");
profession.addIdProperty().autoincrement().notNull();
profession.addStringProperty("name");
profession.addStringProperty("description");

Entity person = schema.addEntity("Person");
person.addIdProperty();
person.addStringProperty("firstName");
person.addStringProperty("lastName");
person.addDateProperty("dateOfBirth");
Property professionProperty = person.addLongProperty("profession_id").getProperty();
person.addToOne(profession, professionProperty);

new DaoGenerator().generateAll(schema, "my/path/java");

插入问题:

现在我正在尝试像这样插入创建的Person对象及其Profession对象:

DaoMaster master = new DaoMaster(devOpenHelper.getWritableDatabase());
    DaoSession session = master.newSession();
    PersonDao personDao = session.getPersonDao();
    List<Person> people = myWebServiceResponse.getPeople();
    ProfessionDao professionDao = session.getProfessionDao();
    personDao.insertOrReplaceInTx(people);
    for (Person person : people) {
        try {
            professionDao.insertInTx(person.getProfession());
        } catch (Exception e) {
            Log.e("MainActivity", "Issue on insert: " + e.getMessage());
        }
    }

person.getProfession()抛出此异常:尝试在空对象引用上调用虚拟方法“long com.example.dao.Profession.getId()

如果我扭转局面,通过插入第Profession一个然后是对象,它会在同一个调用中Person抛出Entity is detached from DAO contextperson.getProfession()

4

1 回答 1

4

恐怕GreenDao和Gson不是一对友好的夫妻。这是因为在 GreenDao 中,必须在对象构造之前插入所有实体。

在这种情况下,Profession 不是一个字段,而是一个关系,因此当您执行 person.getProfession() 时,您是从 Profession 表中检索此值,而不是从 Person 对象中检索该值。您应该插入 Person 和 Profession 对象,然后建立它们的关系。

这两个工具不能很好地协同工作真的很不方便,但据我所知,它是这样工作的。

于 2015-10-28T08:50:49.330 回答