我基本上试图从另一个类的sqlite db获取信息。我在onCreate方法中没有遇到任何问题,但是当我尝试在onCreate内部的onClickListener中使用它时,我无法找到正确的上下文。我的代码如下:
private AutoCompleteTextView search;
private Button showInfoButton;
private TextView courseInfo;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main_courses);
final Context baseContext = getBaseContext();
courseInfo = (TextView) this.findViewById(R.id.text);
DataBase db = new DataBase(this.getApplicationContext());
db.openDataBase();
final ArrayList<String> aCourses = db.getCoursesArr();
db.close();
search = (AutoCompleteTextView) findViewById(R.id.autocomplete_course);
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, R.layout.list_courses, aCourses);
search.setAdapter(adapter);
showInfoButton = (Button) this.findViewById(R.id.show_info_button);
showInfoButton.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
if (aCourses.toString().contains(search.getText()) == false ) {
courseInfo.setText("Please select a course from the drop-down menu and click on the \"Show course information\" button");
}
else{
String selectedCourse = search.toString();
DataBase db1 = new DataBase(baseContext);
db1.openDataBase();
ArrayList<String> courseAttributes = db1.getCourseAttributes();
ArrayList<String> attributeValues = db1.getAttributeValues(selectedCourse);
db1.close();
String courseInformation = "";
for (int i=0; i < courseAttributes.size(); i++){
courseInformation = courseInformation + courseAttributes.get(i) + ": " + attributeValues.get(i) + System.getProperty("line.separator");
}
courseInfo.setText(courseInformation);
}
}
});
}
问题来自
DataBase db1 = new DataBase(baseContext);
我尝试将其更改为
DataBase db = new DataBase(this.getApplicationContext());
和
DataBase db = new DataBase(null);
并且我尝试它的每一种方式,程序都会运行,但是当它在其他情况下,它会抛出错误并关闭。谁能告诉我应该使用什么上下文才能让它运行?
答案 0 :(得分:1)
由于您可能不止一次需要数据库连接,我建议您在自己的应用程序类中打开和关闭数据库连接,该应用程序类扩展Application
。
你有onCreate和onDestroy方法,你可以在这里打开和关闭数据库(因为它有一个上下文)。如果将数据库对象作为类变量(公共静态),则应该能够像MyApplication.mDatabase
一样使用它。