这是我的样本JSON:
{
"open":true,
"total_products":100,
"product":[
{
"p_id":1,
"price":"5.00",
"name":"blah one"
},
{
"p_id":2,
"price":"15.00",
"name":"blah two"
},
...
]
}
这是我的POJO课程:
@Entity(nameInDb = "products")
public class ProductsPOJO {
@SerializedName("open")
@Property(nameInDb = "open")
private boolean open;
@SerializedName("total_products")
@Property(nameInDb = "total_products")
private Long total_products;
@Convert(converter = ProductConverter.class, columnType = String.class)
@SerializedName("product")
@Property(nameInDb = "product")
private Product product;
public static class productConverter implements PropertyConverter<Product, String> {
//What shoudl I write in convert part?!
@Override
public Product convertToEntityProperty(String databaseValue) {
if (databaseValue == null) {
return null;
}
for (Product p : Product.values()) {
if (p.id == databaseValue) {
return p;
}
}
return Product.DEFAULT;
}
@Override
public String convertToDatabaseValue(Product entityProperty) {
return entityProperty == null ? null : entityProperty.;
}
//
/*@Override
public Product convertToEntityProperty(String databaseValue) {
return Product.valueOf(databaseValue);
}
@Override
public String convertToDatabaseValue(Product entityProperty) {
return entityProperty.name();
}*/
}
public static class Product{
@Id
@SerializedName("p_id")
private Long p_id;
@SerializedName("price")
@Property(nameInDb = "price")
private String price;
@SerializedName("name")
@Property(nameInDb = "name")
private String name;
//Getters & Setters
}
public Product getProduct() {
return product;
}
public void setProduct(Product data) {
this.product = product;
}
//open & total_products Getters & Setters
}
但我不知道应该为productConverter
写些什么
另一方面,Product
类中的字段有多种类型。 String
和Integer
。
我看了这些:
https://github.com/greenrobot/greenDAO/blob/V3.1.1/examples/DaoExample/src/main/java/org/greenrobot/greendao/example/Note.java#L26-L27
答案 0 :(得分:1)
编辑 :: /我在这里混淆了两件事,greenrobot objectbox和greendao ...很抱歉,但答案保持不变,只需用greendao替换objectbox:)
在我看来,你把东西与GSON和ObjectBox(GreenDao)混合起来
You Json看起来像服务器一样。但是在您的数据库中,您通常只想保存产品实体,而不是答案。所以最好只有一个ServerResultPOJO用GSON来解析你的答案(下面的代码没有经过测试,可能包含一些小错误,只是为了让你走上正确的道路)。
public class ServerResultPOJO {
@SerializedName("open")
private boolean open;
@SerializedName("total_products")
private Long total_products;
@SerializedName("product")
private List<Product> products;
}
您的Prdouct类可以是ObjectBox(GreenDao)实体
@Entity
public static class Product{
@Id
private long id;
@Index
@SerializedName("p_id")
private Long p_id;
@SerializedName("price")
@Property(nameInDb = "price")
private String price;
@SerializedName("name")
@Property(nameInDb = "name")
private String name;
//Getters & Setters
}
[Id最好不要使用服务器ID作为数据库实体ID。单独保存id和服务器ID。自动增量和其他东西不会混淆]
您不需要任何转换器,只需要将所有产品从您的答案中放入数据库 - 在放置新实体之前,您可以搜索p_id以检查是否需要在放入之前同步到数据库。
首先解析你的答案,然后进行数据库操作。
如果您确实希望将响应作为数据库实体,则需要一对多的关系。但是你不能为实体和GSON解析使用相同的类,或者你使用一些@transient字段,使事情变得更复杂。
答案 1 :(得分:0)
这是因为
&#34; GSON预计BEGIN_ARRAY但是BEGIN_OBJECT&#34;
应该做这样的事情:
JsonParser parser = new JsonParser();
JsonObject rootObject = parser.parse(JSON_STRING).getAsJsonObject();
//You can get the "open" and "total_products" here too.//
JsonElement productElement = rootObject.get("product");
Gson gson = new Gson();
List<Product> productList = new ArrayList<>();
//Check if "data" element is an array or an object and parse accordingly...
if (productElement.isJsonObject()) {
//The returned list has only 1 element
Product p = gson.fromJson(productElement, Product.class);
productList.add(p);
}
else if (productElement.isJsonArray()) {
//The returned list has >1 elements
Type productListType = new TypeToken<List<Product>>() {}.getType();
productList = gson.fromJson(productElement, productListType);
}
[来源:heap]