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"表中插入所有数组项?
任何帮助将不胜感激.
您必须修复几行代码,首先是删除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)
| 归档时间: |
|
| 查看次数: |
9042 次 |
| 最近记录: |