将一组数据传递到android中的SQLite数据库

use*_*552 4 arrays sqlite android

我正在使用数组将数据发送到我的SQLite数据库.
该数组包含所有选定的值.

 private void addContacts(String[] selectedItems) {

    manager.Insert_phone_contact(selectedItems);
    Intent i = new Intent(this, MainActivity.class);    
    startActivity(i);
}
Run Code Online (Sandbox Code Playgroud)

我的SQLite数据库代码在contentvalues中插入上面提到的"selectedItems"数组如下:

public void Insert_phone_contact(String [] contact){
    try{

        SQLiteDatabase DB = this.getWritableDatabase();
        for(int i=0;i<contact.length;i++){
            ContentValues cv = new ContentValues();
            cv.put(CONTACT_NAME, contact[i]);
            DB.insert(TABLE_CONTACTS, null, cv);
            DB.close();
        }
        }
    catch(Exception ex){
        Log.e("Error in phone contact insertion", ex.toString());
    }
Run Code Online (Sandbox Code Playgroud)

只有第一个数组项存储在ContentValuescv中,而不是所有数组元素中.
这段代码有什么问题?
如何在"TABLE_CONTACTS"表中插入所有数组项?
任何帮助将不胜感激.

Dar*_*vil 7

您必须修复几行代码,首先是删除Db.Close()并在循环后添加它您尝试的代码是在第一次插入后关闭Db对象,其余循环迭代不可用.

public void Insert_phone_contact(String [] contact){
try{

    SQLiteDatabase DB = this.getWritableDatabase();
    ContentValues cv = new ContentValues(); //Declare once
    for(int i=0;i<contact.length;i++){            
        cv.put(CONTACT_NAME, contact[i]);
        DB.insert(TABLE_CONTACTS, null, cv); //Insert each time for loop count            
    }
    DB.close(); // Now close the DB Object
    }
catch(Exception ex){
    Log.e("Error in phone contact insertion", ex.toString());
}
Run Code Online (Sandbox Code Playgroud)