我正在尝试解决我一直在与其进行斗争的'敲定'错误。在我尝试了许多不同的数据库和cursor'.close()'方法之后,这个问题仍然存在。
显示的代码是现在的样子。如果有人可以指导我以正确的方式关闭我的光标和数据库,那将是很好的,因为如果我关闭一个,它似乎与另一个冲突!
目前,我正在尝试使用从对话框列表的Intent中调用的“AddAppointmentContact”类的“onCreate”方法中的对象方法集中设置检索到的字符串值来设置“EditText”。
目前我收到此错误:
错误:
02-01 21:23:18.947: E/Cursor(274): Finalizing a Cursor that has not been deactivated or closed. database = /data/data/com.example.flybase2/databases/persons_name, table = contactsTable, query = SELECT _id, persons_name, persons_telephone, persons_email, persons_comments FROM contactsTable WHER
我在我的代码中运行类似的代码,这样可以正常工作。
这是与我保存对话框的列表视图中选择的名称ID捆绑在一起的代码:
else if (items[item].equals("Add Appointment")) {
Intent conAdd = new Intent("com.example.flybase2.AddAppointmentContact");
conAdd.putExtra("newpassedID", idToPass);
startActivity(conAdd);
打开的“AddAppointmentContact”类:
Bundle extras = getIntent().getExtras();
sentID = extras.getLong("newPassedID");
DBHandlerApp NameAppointPass = new DBHandlerApp(this, null, null);
NameAppointPass.open();
String nameReturned = NameAppointPass.getName(sentID);
setName = (EditText) findViewById(R.id.inputAppName);
setName.setText(nameReturned);
'.getName()'方法:
public String getName(long passedID) {
String [] columns = new String[]{KEY_ROWAPPID, KEY_NAMEAPP, KEY_TYPEAPP, KEY_TIMEAPP, KEY_DATEAPP, KEY_COMMENTAPP};
Cursor c = ourDatabase.query(DATABASE_TABLEAPP, columns, KEY_ROWAPPID + "=" + passedID, null, null, null, null);
if(c != null && c.getCount() > 0)
{
c.moveToFirst();
String name = c.getString(1);
return name;
}
return null;
答案 0 :(得分:0)
您需要关闭光标。
返回name之前 c.close()
或null。
答案 1 :(得分:0)
同意您必须关闭Cursor
。试试这个:
if(c != null) {
if(c.getCount() > 0 && c.moveToFirst())
{
String name = c.getString(1);
c.close();
return name;
}
c.close();
}
return null;