Извините за мой английский.
Пожалуйста, не отрицательный результат!
Я знаю, как искать 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()
не работает!
В чем проблема?
Ваш запрос является проблемой.
Посмотрите, что вы делаете:
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 + "'" ;
Примечание. Я не могу быть более точным, так как я не знаю названия вашей таблицы и названия поля Title.
Во всяком случае, я считаю это довольно простым.
Примечание (2): Использование связанных параметров, как было предложено @pskink, было бы лучшим вариантом, чем использование разделителей строк.
rawQuery
вы увидите, что он имеет два параметра, читайте о втором