Android:SQLite保存字符串数组?

use*_*899 31 android android-sqlite

我需要将一个字符串数组保存到数据库,但它不会让我.这就是我所拥有的:

 public long createEntry(String startTime, String endTime, String[] states) {
         ContentValues initialValues = new ContentValues();
         initialValues.put(START_KEY_TIME , startTime);
         initialValues.put(END_KEY_TIME , endTime);
         initialValues.put(KEY_STATE, states );

         return databaseConnect.insert(DATABASE_TABLE, null, initialValues);
}
Run Code Online (Sandbox Code Playgroud)

但是,如果我把string[]状态放入,它说内容值不能参与.我该如何解决这个问题?我以为我在状态中有7个东西,我可以喜欢有7个单独的字符串并在每个中存储东西然后将所有字符串放回字符串数组中吗?或者这是不好的做法?

Muh*_*rif 80

您无法将String数组保存到数据库中.但你可以使用这个技巧.

1)所以你必须使用convertArrayToString(String[] array)方法将它转换为简单的String .这将使用'逗号'连接字符串的所有元素.

2)当您从数据库中检索此String时,您可以使用convertStringToArray(String str)方法将其转换回String数组.此方法将从"逗号"中拆分字符串,您将获得原始数组.

public static String strSeparator = "__,__";
public static String convertArrayToString(String[] array){
    String str = "";
    for (int i = 0;i<array.length; i++) {
        str = str+array[i];
        // Do not append comma at the end of last element
        if(i<array.length-1){
            str = str+strSeparator;
        }
    }
    return str;
}
public static String[] convertStringToArray(String str){
    String[] arr = str.split(strSeparator);
    return arr;
}
Run Code Online (Sandbox Code Playgroud)

  • 如果数组的任何元素包含',',这将不起作用 (4认同)
  • 这个专栏很难查询对吗? (4认同)

Nat*_*ein 12

基于穆罕默德的答案,但手柄ListStrings,而不是数组,并使用StringBuilder的,而不是分配多String值级联在S:

private static final String LIST_SEPARATOR = "__,__";

public static String convertListToString(List<String> stringList) {
    StringBuilder stringBuilder = new StringBuffer();
    for (String str : stringList) {
        stringBuilder.append(str).append(LIST_SEPARATOR);
    }

    // Remove last separator
    stringBuilder.setLength(stringBuilder.length() - LIST_SEPARATOR.length());

    return stringBuilder.toString();
}

public static List<String> convertStringToList(String str) {
    return Arrays.asList(str.split(LIST_SEPARATOR));
}
Run Code Online (Sandbox Code Playgroud)


Aun*_*iha 9

将其转换为单个String以将其保存在sqlite中.稍后,将其作为单个字符串从sqlite中检索回来,并将其转换回Array of String.

String ARRAY_DIVIDER = "#a1r2ra5yd2iv1i9der";

public String serialize(String content[]){      
    return TextUtils.join(ARRAY_DIVIDER, content);
}

public String[] derialize(String content){
    return content.split(ARRAY_DIVIDER);
}
Run Code Online (Sandbox Code Playgroud)


jia*_*hao 5

如果您将字符串数组转换为 JSONArray,使用 toString 然后通过首先解析为 JSONArray 然后将其转换为字符串数组来检索它会更容易