搜索结果错误 Android SQLite
Error in search result Android SQLite
我创建了一个显示地点列表的应用程序,并创建了一个搜索对话框,用户可以在其中输入编辑文本,这样 he/she 就会找到所需的地点。但是我得到一个错误,我将在下面 post。
Attempt to invoke virtual method 'android.text.Editable android.widget.EditText.getText()' on a null object reference at com.example.ubaldo.myapplication.Place.onClick(Place.java:221)
这是我代码中的第 221 行
GetSearchPlace = dbhelper.getPlaceSearch(placeLocationEditText.getText().toString());
这是我的数据库助手
public List<PlaceModel> getPlaceSearch(String location) {
List<PlaceModel> search = new ArrayList<PlaceModel>();
String selectQuery = "SELECT * FROM listing_place where province_name like '" + location + "'";
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
if (cursor.moveToFirst()) {
do {
PlaceModel pm = new PlaceModel();
pm.setlisting_title(cursor.getString(cursor.getColumnIndex(KEY_PLACE)));
search.add(pm);
}
while (cursor.moveToNext());
}
cursor.close();
return search;
}
这是我的主activity
placeLocationEditText = (EditText)findViewById(R.id.placelocation);
Button button = (Button) dialog.findViewById(R.id.btnplacesearch);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
PlaceListView = findViewById(R.id.placelayout);
ViewGroup parent = (ViewGroup) PlaceListView.getParent();
parent.removeView(PlaceListView);
PlaceSearchView = getLayoutInflater().inflate(R.layout.searchresult_place, parent, false);
parent.addView(PlaceSearchView);
GetSearchPlace = dbhelper.getPlaceSearch(placeLocationEditText.getText().toString());
lv2 = (ListView) findViewById(R.id.searchplace_list);
lv2.setAdapter(new ViewAdapterSearchPlace());
替换
placeLocationEditText = (EditText)findViewById(R.id.placelocation);
和
placeLocationEditText = (EditText)dialog.findViewById(R.id.placelocation);
我创建了一个显示地点列表的应用程序,并创建了一个搜索对话框,用户可以在其中输入编辑文本,这样 he/she 就会找到所需的地点。但是我得到一个错误,我将在下面 post。
Attempt to invoke virtual method 'android.text.Editable android.widget.EditText.getText()' on a null object reference at com.example.ubaldo.myapplication.Place.onClick(Place.java:221)
这是我代码中的第 221 行
GetSearchPlace = dbhelper.getPlaceSearch(placeLocationEditText.getText().toString());
这是我的数据库助手
public List<PlaceModel> getPlaceSearch(String location) {
List<PlaceModel> search = new ArrayList<PlaceModel>();
String selectQuery = "SELECT * FROM listing_place where province_name like '" + location + "'";
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
if (cursor.moveToFirst()) {
do {
PlaceModel pm = new PlaceModel();
pm.setlisting_title(cursor.getString(cursor.getColumnIndex(KEY_PLACE)));
search.add(pm);
}
while (cursor.moveToNext());
}
cursor.close();
return search;
}
这是我的主activity
placeLocationEditText = (EditText)findViewById(R.id.placelocation);
Button button = (Button) dialog.findViewById(R.id.btnplacesearch);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
PlaceListView = findViewById(R.id.placelayout);
ViewGroup parent = (ViewGroup) PlaceListView.getParent();
parent.removeView(PlaceListView);
PlaceSearchView = getLayoutInflater().inflate(R.layout.searchresult_place, parent, false);
parent.addView(PlaceSearchView);
GetSearchPlace = dbhelper.getPlaceSearch(placeLocationEditText.getText().toString());
lv2 = (ListView) findViewById(R.id.searchplace_list);
lv2.setAdapter(new ViewAdapterSearchPlace());
替换
placeLocationEditText = (EditText)findViewById(R.id.placelocation);
和
placeLocationEditText = (EditText)dialog.findViewById(R.id.placelocation);