使用数据库

时间:2015-12-10 15:02:02

标签: android sqlite listview search android-sqlite

对不起我的英文。
请不要负分!

我知道如何搜索动态视图的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 个答案:

答案 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所建议的那样,比使用字符串分隔符更好。