对不起我的英文。
请不要负分!
我知道如何搜索动态视图的ListView ...
但我不知道如何搜索提供ListView的数据库。
您能告诉我如何搜索ListView中显示的代码并从数据库中获取值吗?
这是我的数据库类代码:
public DrLists findProduct(String Title) {
String query = "Select * FROM " + TABLE_NAME + " WHERE " + TABLE_NAME + " = \"" + Title + "\"" ;
SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery(query, null);
drLists=new DrLists();
if (cursor.moveToFirst()) {
cursor.moveToFirst();
drLists.setId(Integer.parseInt(cursor.getString(0)));
drLists.setName(cursor.getString(1));
drLists.setFamily(cursor.getString(2));
cursor.close();
} else {
drLists = null;
}
db.close();
return drLists;
}
这是我的活动代码:
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.navigation);
databaseAssets=new DatabaseAssets(getApplicationContext());
try {
databaseAssets.createDataBase();
databaseAssets.openDataBase();
}catch (IOException e){
e.printStackTrace();
}
editText=(EditText)findViewById(R.id.edt_search);
Button search = (Button)findViewById(R.id.btn_search);
drawerLayout = (DrawerLayout) findViewById(R.id.my_drawerlayout);
navigationView = (NavigationView) findViewById(R.id.my_navigation);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this,
drawerLayout, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
drawerLayout.setDrawerListener(toggle);
toggle.syncState();
search.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
drLists=new DrLists();
drLists=databaseAssets.findProduct(editText.getText().toString());
}
});
但findProduct()
不起作用!
有什么问题?
答案 0 :(得分:0)
您的疑问是问题 看看你在做什么:
String query = "Select * FROM " + TABLE_NAME + " WHERE " + TABLE_NAME + " = \"" + Title + "\"" ;
将在SQL中翻译成类似
的内容SELECT * FROM My_TABLE_NAME WHERE My_TABLE_NAME = "Some Title"
您需要将其更改为
String query = "SELECT * FROM " + TABLE_NAME + " WHERE " + TITLE_FIELD + " = '" + Title + "'" ;
注意:我不能更准确,因为我不知道你的桌子的名字,也不知道你的标题字段的名称。
无论如何,我认为这很简单。
注意(2):使用绑定参数,正如@pskink所建议的那样,比使用字符串分隔符更好。