10

我有一个模型对象。其中,我有多个值。我想将此值存储在 SQLite 中。但是数据很大,所以我想将 Direct Model 对象存储在数据库中。所以我将模型对象转换为字符串并将其存储到数据库中。

现在,问题是如何将此字符串值转换为模型对象。如果您有任何想法,请与我分享。

例如,

Person p = new Person();
p.setname("xyz");
p.setage("18");`

String person=p.toString();

现在如何让这个“人”字符串回到Personp”模型对象。

这是我的代码。

ContentValues values = new ContentValues();
    String favorite_id = UUID.randomUUID().toString();
    values.put(EMuseumLocalData.KEY_FAVORITE_EXHIBITS_ID, favorite_id);
    values.put(EMuseumLocalData.KEY_EXHIBIT_SUBCATEGORY_ITEM_ID, Integer.parseInt(categoryByCustomerList.get(position).getSubCategoryItemID()));
    try {
        Gson gson = new Gson();
        String personString = gson.toJson(getAllCategory.get(position).toString());
        values.put(EMuseumLocalData.KEY_EXHIBIT_SUBCATEGORY_ITEM_DATA, personString);

        Gson gson1 = new Gson();
        CategoryByCustomer categoryByCustomer = gson1.fromJson(personString, categoryByCustomer.getName());
    } catch (JSONException e) {
        e.printStackTrace();
    }
4

3 回答 3

18

您应该GSON为此使用或类似的库。


存储到数据库

例如,如果您使用GSON

Person p = new Person();
p.setname("xyz");
p.setage("18");
Gson gson = new Gson();
String personString = gson.toJson(p);

现在将此 personString 存储到 DB。


从数据库读取

从数据库中取回该对象,从数据库中读取字符串并将其转换为如下对象

String personStringFromDB = READ_LOGIC_OF_DB;
Gson gson = new Gson();
Person p = gson.fromJson(personStringFromDB, Person.class);

有关更多信息,请阅读GSON - Gson 示例

于 2016-07-07T06:34:38.123 回答
0

考虑使用模型对象的json字符串表示。有许多 java 库,如 Jackson、Gson 等,可帮助您进行序列化/反序列化部分。

这是在杰克逊执行此操作的示例代码

//For conversion of Person object(person) to json String:

String personJsonString = new com.fasterxml.jackson.databind.ObjectMapper().writeValueAsString(person);


//For conversion of json String back to Person object(person)

Person person = new com.fasterxml.jackson.databind.ObjectMapper().readValue(personJsonString, Person.class);
于 2016-07-07T06:28:16.450 回答
0

您可以使模型对象可序列化。您需要将序列化的对象存储在 SQLite 中。当您需要它时,您只需从 SOLite 获取该序列化对象并反序列化它。

于 2016-07-07T06:29:10.390 回答