“InitDatabase()”被称为“inserRecord()”,但它每次都显示异常,并且在insertRecord()中我还调用了 closeDatabase(),其中我有关闭 DB(数据库)的代码。
1.插入数据运行时出错:
在程序开始时,我使用insertRecord()输入记录,它工作正常,但是在运行时,当我用来插入记录时,它返回新的行 ID,但是当我select * from table
然后它不会显示最后插入的记录
2、在HashMap中存储Cursor:
如果在该应用程序中需要,是否可以将光标进一步存储在哈希图中。
public SQLiteDatabase initDatabase(){
Log.v("XIG","creating or opening database.");
db_helper= new DatabaseHelper(context,dbname,1);
DB = context.openOrCreateDatabase(dbname,SQLiteDatabase.CREATE_IF_NECESSARY, null);
DB.setVersion(1);
DB.setLocale(Locale.getDefault());
DB.setLockingEnabled(true);
DB = db_helper.getWritableDatabase();
return DB;
}
public void insertRecord(String Table,String columnId[],String value[],String typeOfValue[]){
initDatabase();
Log.v("XIG","creating new record.");
ContentValues new_record = new ContentValues();
for(int i=0; i<columnId.length; i++){
if(typeOfValue[i].equals("INT")){
new_record.put(columnId[i],Integer.parseInt(value[i]));
}
else{
new_record.put(columnId[i],value[i]);
}
}
long rowid;
try{
DB.beginTransaction();
rowid = DB.insert(Table,null,new_record);
DB.setTransactionSuccessful();
}
finally{
DB.endTransaction();
}
Log.v("XIG","inserted rowid in "+Table+": "+rowid);
closeDatabase();
}
例外:
initDatabase() method shows exception :
07-12 13:15:32.415: E/SQLiteDatabase(13643): close() was never explicitly called on database '/data/data/com.app/databases/mydb3'
07-12 13:15:32.415: E/SQLiteDatabase(13643): android.database.sqlite.DatabaseObjectNotClosedException: Application did not close the cursor or database object that was opened here