Невозможно сохранить вложенные части запроса JSON, используя robospice и ormlite.
Привет, мы используем RoboSpice с ORMLite и SpringAndroidSpiceRequest для чтения информации JSON с веб-страницы и записи в базу данных SQLite.
Мы используем новейший JSON Mapper MappingJackson2HttpMessageConverter.
// Web services support JSON responses
MappingJackson2HttpMessageConverter jsonConverter = new MappingJackson2HttpMessageConverter();
FormHttpMessageConverter formHttpMessageConverter = new FormHttpMessageConverter();
StringHttpMessageConverter stringHttpMessageConverter = new StringHttpMessageConverter();
final List<HttpMessageConverter<?>> listHttpMessageConverters = restTemplate.getMessageConverters();
Мы попытались прочитать вложенные JSON-запросы, как в примере ниже, мы можем прочитать и сохранить в базе данных первый уровень JSON (страница, всего), но мы не можем сохранить следующий уровень массива JSON, All "schedule_date" "записи.
Мы рассмотрели этот пример (и многие другие) как лучший пример для хранения данных JSON. Но это не работает для нас. RoboSpice сохраняют массив JSON с помощью OrmLite
Вопрос: Как мы можем прочитать и записать вложенные ключи и значения JSON, Мы в тупике!: O
JSON:
{
"page": 2,
"total": 5,
"result":
[
{
"schedule_date": "2013-08-03"
},
{
"schedule_date": "2013-09-03"
},
{
"schedule_date": "2013-10-03"
},
{
"schedule_date": "2013-11-03"
},
{
"schedule_date": "2013-12-03"
}
]
}
BroadcastResult.java:
import java.util.Collection;
import java.util.List;
import com.j256.ormlite.field.DatabaseField;
import com.j256.ormlite.table.DatabaseTable;
import com.j256.ormlite.field.ForeignCollectionField;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
@JsonIgnoreProperties(ignoreUnknown = true)
@DatabaseTable(tableName="BroadcastResult")
public class BroadcastResult {
@DatabaseField(id = true)
private int page;
@DatabaseField
private int total;
@ForeignCollectionField(eager = false)
private Collection<Broadcast> result;
public int getPage() {
return page;
}
public void setPage(int page) {
this.page = page;
}
public int getTotal() {
return total;
}
public void setTotal(int total) {
this.total = total;
}
public Collection<Broadcast> getResult() {
return result;
}
public void setResult(Collection<Broadcast> result) {
this.result = result;
}
}
Broadcast.java:
import com.j256.ormlite.field.DatabaseField;
import com.j256.ormlite.table.DatabaseTable;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
@JsonIgnoreProperties(ignoreUnknown = true)
@DatabaseTable(tableName="Broadcast")
public class Broadcast {
@DatabaseField(id = true)
private String schedule_date;
@DatabaseField(foreign = true)
private BroadcastResult result;
public String getScheduleDate() {
return schedule_date;
}
public void setScheduleDate(String schedule_date) {
this.schedule_date = schedule_date;
}
public void setBroadcastResult(BroadcastResult result) {
this.result = result;
}
public BroadcastResult getBroadcastResult() {
return result;
}
}
Мы получили эту ошибку, которую мы не понимаем.
Logcat: SQLiteLog (10637): (1) такого столбца нет: result_id
@DatabaseField(foreign = true) // also tried (foreign = true, ColumnName="result")
private BroadcastResult result;
Полный журнал для запуска теста можно увидеть здесь: https://gist.github.com/anonymous/7760344
1 ответ
Вы пытались добавить
@DatabaseField(generatedId = true)
private int _id;
в ваш класс Broadcast.java?