我是 Android 编程新手,我正在尝试创建一个应用程序,用户可以在其中从 2 个微调器中选择一些选项,点击搜索按钮后,应用程序将根据所选选项搜索数据库,结果将显示. 问题是我不确定将哪些参数放入 db.rawQuery 以使用所选微调器选项的值进行搜索。我试图在下面进行粗略的猜测,但它不起作用,我不确定如何使用这两个条件进行搜索。
这是微调器的编码:
public class First extends Activity {
private Spinner foodSpinner, locationSpinner;
private Button btnSubmit;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.first);
addListenerOnButton();
}
public void addListenerOnButton() {
foodSpinner = (Spinner) findViewById(R.id.foodSpinner);
locationSpinner = (Spinner) findViewById(R.id.locationSpinner);
btnSubmit = (Button) findViewById(R.id.btnSubmit);
btnSubmit.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
Intent intent = new Intent(First.this.getApplicationContext(), MainActivity.class);
intent.putExtra("FOODSPINNER", foodSpinner.getSelectedItem().toString());
intent.putExtra("LOCATIONSPINNER", locationSpinner.getSelectedItem().toString());
First.this.startActivity(intent);
}
});
}
这是搜索的编码:
public class MainActivity extends ListActivity {
protected SQLiteDatabase db;
protected Cursor cursor;
protected ListAdapter adapter;
protected String foodItemChosen;
protected String locationItemChosen;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Bundle extras = getIntent().getExtras();
foodItemChosen = getIntent().getExtras().getString("FOODSPINNER");
locationItemChosen = extras.getString("LOCATIONSPINNER");
db = (new DatabaseHelper(this)).getWritableDatabase();
}
public void onListItemClick(ListView parent, View view, int position, long id) {
Intent intent = new Intent(this, ResultDetails.class);
Cursor cursor = (Cursor) adapter.getItem(position);
intent.putExtra("FOOD_ID", cursor.getInt(cursor.getColumnIndex("_id")));
startActivity(intent);
}
public void search(View view) {
cursor = db.rawQuery("SELECT _id, name, address FROM database WHERE food LIKE ?",
new String[]{"%" '+foodItemChosen+' "%"});
adapter = new SimpleCursorAdapter(
this,
R.layout.result_list_item,
cursor,
new String[] {"name", "address"},
new int[] {R.id.name, R.id.address});
setListAdapter(adapter);
}
}