Не удалось создать элемент данных в ForeignCollection ORMLite
У меня есть контактные и групповые занятия. Каждый контакт может быть во многих группах, и одна группа может иметь много контактов. Мои занятия:
@DatabaseTable(tableName = "contacts")
public class ContactItem implements Parcelable{
private static final long serialVersionUID = 1L;
@DatabaseField(generatedId = true)
private Integer id;
@DatabaseField(dataType = DataType.STRING, columnName = Constants.CONTACT_NAME)
private String name;
@DatabaseField(dataType = DataType.STRING, columnName = Constants.CONTACT_NUMBER)
private String number;
@DatabaseField(dataType = DataType.INTEGER, columnName = Constants.CONTACT_ICON)
private int icon;
@DatabaseField(dataType = DataType.INTEGER, columnName = Constants.CONTACT_DAYS)
private int days;
@DatabaseField(foreign=true,canBeNull = true,foreignAutoRefresh = true,columnName = Constants.CONTACT_GROUP)
private GroupItem group;
@ForeignCollectionField(columnName = Constants.CONTACT_GROUP_LIST)
}
@DatabaseTable(tableName = "groups")
public class GroupItem implements Parcelable{
@DatabaseField(generatedId = true)
private Integer id;
@DatabaseField(dataType = DataType.STRING, columnName = Constants.GROUP_NAME)
private String name;
@DatabaseField(dataType = DataType.INTEGER, columnName = Constants.GROUP_ICON)
private int icon;
@DatabaseField(dataType = DataType.INTEGER, columnName = Constants.GROUP_COUNT)
private int count;
@DatabaseField(foreign=true,canBeNull = true,foreignAutoRefresh = true, columnName = Constants.GROUP_CONTACT)
private ContactItem contact;
@ForeignCollectionField(eager = true, columnName=Constants.GROUP_CONTACTS_LIST)
private ForeignCollection<ContactItem> contacts;
}
И когда мне нужно добавить список контактов в указанную группу, я делаю что-то вроде этого:
public void saveGroupContacts(GroupItem group, ArrayList<ContactItem> contacts)
{
DatabaseHandler db = new DatabaseHandler(context.getApplicationContext());
Dao<GroupItem,Integer> daoGroup = null;
GroupItem newGroup;
try {
daoGroup = db.getGroupDao();
UpdateBuilder<GroupItem, Integer> updateBuilder = daoGroup.updateBuilder();
newGroup = daoGroup.queryForId(group.getId());
Log.i(" received group from database", newGroup.toString());
ForeignCollection<ContactItem> fAp =
daoGroup.getEmptyForeignCollection(Constants.GROUP_CONTACTS_LIST);
Log.i("foreign coll size", Integer.toString(fAp.size()));
for (ContactItem contact: contacts)
{
Log.i("contact to save in group", contact.toString());
contact.setContactGroup(group);
group.setContact(contact);
fAp.add(contact);
}
daoGroup.update(newGroup);
}
catch(Exception e)
{
e.printStackTrace();
}
}
но получить
java.lang.IllegalStateException: Could not create data element in dao
Как я могу это исправить?
1 ответ
Решение
Я решил мою проблему в этом случае:
public void saveNonExistingGroupContacts(GroupItem group, ArrayList<ContactItem> contacts)
{
DatabaseHandler db = new DatabaseHandler(context.getApplicationContext());
Dao<GroupItem,Integer> daoGroup = null;
Dao<ContactItem,Integer> daoContact = null;
GroupItem newGroup;
try {
daoGroup = db.getGroupDao();
daoContact= db.getContactDao();
UpdateBuilder<ContactItem, Integer> contactUpdateBuilder = daoContact.updateBuilder();
UpdateBuilder<GroupItem, Integer> groupUpdateBuilder = daoGroup.updateBuilder();
daoGroup.createIfNotExists(group);
newGroup = daoGroup.queryForId(group.getId());
ForeignCollection<ContactItem> fAp =
daoGroup.getEmptyForeignCollection(Constants.GROUP_CONTACTS_LIST);
for (ContactItem contact: contacts)
{
contact.setContactGroup(group);
newGroup.setContact(contact);
newGroup.setCount(newGroup.getCount()+1);
contactUpdateBuilder.updateColumnValue(Constants.CONTACT_GROUP,newGroup);
groupUpdateBuilder.updateColumnValue(Constants.GROUP_CONTACT,contact);
}
contactUpdateBuilder.update();
groupUpdateBuilder.update();
}
catch(Exception e)
{
e.printStackTrace();
}
}