Поиск пользовательского списка с базой данных

-3

Извините за мой английский.
Пожалуйста, не отрицательный результат!

Я знаю, как искать 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() не работает!
В чем проблема?

  • 1
    если вы увидите документацию по rawQuery вы увидите, что он имеет два параметра, читайте о втором
  • 0
    Спасибо за советы. Но я не понимаю, что такое TITLE_FIELD?
Показать ещё 7 комментариев
Теги:
search
android-sqlite
listview

1 ответ

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 + "'" ;

Примечание. Я не могу быть более точным, так как я не знаю названия вашей таблицы и названия поля Title.
Во всяком случае, я считаю это довольно простым.


Примечание (2): Использование связанных параметров, как было предложено @pskink, было бы лучшим вариантом, чем использование разделителей строк.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню