0

我想搜索数据库中存在的特定关键字并将它们展示出来。

这是我的搜索类代码:

String s = kw.getText().toString();

sqlhandler show = new sqlhandler(this);
show.open();
String rname = show.getName(s);
show.close();
tv.setText(rname);

这是我的数据库类:

public String getName(String kw) {

    String[] columns = new String[] {NAME, APRICE, DPRICE, VENDOR, KEYWORD };

    Cursor c = ourDatabase.query(DATABASE_TABLE, columns, "DPRICE like " + "'%"+ kw+"%'", null, null, null, null);

    String sresult = "";

    int iname = c.getColumnIndex(NAME);
    int iap = c.getColumnIndex(APRICE);
    int idp = c.getColumnIndex(DPRICE);
    int ivendor = c.getColumnIndex(VENDOR);

    for (c.moveToFirst(); !c.isAfterLast(); c.moveToNext()) {
        sresult = sresult + c.getString(iname)+ " "+c.getString(iap)
            + "  " + c.getString(idp) + "  " + c.getString(ivendor)
        + "\n";
    }

    return sresult;
}

我的问题是什么?每次我运行它时,我都会不断接近。

4

1 回答 1

0

由于您尚未发布 LogCat,我只能猜测,但您的 WHERE 子句看起来很可疑:

"DPRICE like ..."

我假设DPRICE是一个变量,而不是实际的列名:

DPRICE + " like ..."

另外我有几点建议:

  • 使用该selectionArgs参数可以防止SQL 注入攻击
  • 考虑使用ListView 和 SimpleCursorAdapter来显示您的数据。
  • 仅选择您正在使用的列。
  • 使用 while 循环而不是 for 循环来遍历 Cursor(您的 for 循环所做的工作是必要工作的三倍)。

全部一起:

public String getName(String kw) {
    String[] columns = new String[] {NAME, APRICE, DPRICE, VENDOR};
    Cursor c = ourDatabase.query(DATABASE_TABLE, columns, DPRICE + " like ?", new String[] {"'%" + kw + "%'"}, null, null, null, null);

    int iname = c.getColumnIndex(NAME);
    int iap = c.getColumnIndex(APRICE);
    int idp = c.getColumnIndex(DPRICE);
    int ivendor = c.getColumnIndex(VENDOR);

    // moveToNext() returns true when there is more data to read 
    //     or false when the cursor isAfterLast()
    StringBuilder builder = new StringBuilder();
    while (c.moveToNext()) {
        builder.append(c.getString(iname).append(" ")
               .append(c.getString(iap).append("  ")
               .append(c.getString(idp).append("  ")
               .append(c.getString(ivendor).append("\n");
    }

    return builder.toString();
}

这是一个关于如何使用具有自定义布局的 ListView 来显示来自数据库的信息的教程。

于 2012-08-31T16:04:41.680 回答