搜索存储在sqlite数据库中的字符串的最快方法

时间:2012-12-04 04:05:08

标签: android sqlite

我有大量的字符串,大约15,000个,我使用以下代码存储在SQLite数据库中:

 void addKey(String key, String value, String table) {
        SQLiteDatabase db = this.getWritableDatabase();

        ContentValues values = new ContentValues();
        values.put(KEY_KEY, key); // Contact Name
        values.put(KEY_VALUE, value); // Contact Phone

        // Inserting Row
        db.insert(table, null, values);
        db.close(); // Closing database connection

    }

然后我使用以下方法搜索该数据库,以便挑选出与我正在寻找的密钥相匹配的任何字符串:

public String searchKeyString(String key, String table){
        String rtn = "";
        Log.d("searchKeyString",table);

            // Select All Query
            String selectQuery = "SELECT  * FROM " + table;

            SQLiteDatabase db = this.getWritableDatabase();
            Cursor cursor = db.rawQuery(selectQuery, null);

            // looping through all rows and adding to list
            if (cursor.moveToFirst()) {
                do {
                    Log.d("searchKeyString","searching");

                    if(cursor.getString(1).equals(key)) 
                        rtn = rtn + "," + cursor.getString(2);
                } while (cursor.moveToNext());
            }
            cursor.close();
            db.close();
            Log.d("searchKeyString","finish search");

        return rtn;
    }

目标是在用户在保留板上键入时实时执行此操作,因此响应时间是关键,现在它的方式需要一秒钟才能完成搜索。

我考虑过最初将所有项目读入数组列表并对可能更快的内容进行排序,但我认为该大小的数组列表可能会导致内存问题。在我的数据库中搜索这些条目的最佳方法是什么?

4 个答案:

答案 0 :(得分:8)

你可以做几件事......

  • 将返回值更改为StringBuilder直到结束。
  • 只使用数据库的可读版本(虽然可能没有太大区别)
  • 每次都不要获取数据库的新实例,在它不再需要之前保持打开状态
  • 仅在SQL查询中使用“WHERE”参数查询所需内容。

请参阅以下代码并进行一些更改:

// move this somewhere else in your Activity or such
SQLiteDatabase db = this.getReadableDatabase();

public String searchKeyString(String key, String table){
    StringBuilder rtn = new StringBuilder();
    Log.d("searchKeyString",table);

        // Select All Query
        String selectQuery = "SELECT  * FROM " + table + " WHERE KEY_KEY=?";

        Cursor cursor = db.rawQuery(selectQuery,  new String[] {key});
        // you can change it to
        // db.rawQuery("SELECT * FROM "+table+" WHERE KEY_KEY LIKE ?", new String[] {key+"%"});
        // if you want to get everything starting with that key value

        // looping through all rows and adding to list
        if (cursor.moveToFirst()) {
            do {
                Log.d("searchKeyString","searching");

                rtn.append(",").append(cursor.getString(2));
            } while (cursor.moveToNext());
        }
        cursor.close();
        Log.d("searchKeyString","finish search");

    return rtn.toString();
}

请注意,即使您希望用户“实时”进行此操作,您仍然需要将其移至单独的Thread或ASyncTask,否则您将遇到问题....

答案 1 :(得分:2)

例如,您应该考虑使用SELECT * FROM your-table LIMIT 50。你可以在视图上放两个按钮“Back”,“Next”。如果每个页面最多有50个项目,则用户位于第1页,然后他点击“下一步”,然后您可以使用此查询:

SELECT * FROM your-table LIMIT 50 OFFSET 50

如果您的表包含大部分文本数据,并且您希望将搜索深入集成到您的应用中,请考虑将虚拟表与FTS一起使用。

答案 2 :(得分:0)

我不知道更好,但也许更快逐个查询所选字符串。

public String searchKeyString(String key, String table){
    String rtn = "";
    Log.d("searchKeyString",table);

    // Select All Query
    String selectQuery = "SELECT  * FROM " + table + "WHERE column_1 = " + key;

    SQLiteDatabase db = this.getWritableDatabase();
    Cursor cursor = db.rawQuery(selectQuery, null);

    // looping through all rows and adding to list
    if (cursor.moveToFirst()) {
        rtn = rtn + "," + cursor.getString(2);
    }
    cursor.close();
    db.close();
    Log.d("searchKeyString","finish search");

    return rtn;
}

修改

我不知道这些自定义键盘应用程序是如何做到的,但那些AutoCompleteTextViews已连接到适配器。您可以轻松制作cursorAdapter并将自动完成视图挂钩。

http://www.outofwhatbox.com/blog/2010/11/android-autocompletetextview-sqlite-and-dependent-fields/

http://www.opgenorth.net/blog/2011/09/06/using-autocompletetextview-and-simplecursoradapter-2/

答案 3 :(得分:0)

让sqlite进行艰难的解除。

首先,如果您还没有索引,请在您要搜索的字段中添加索引。其次,不要使用手动表扫描执行SELECT all,而是使用

形式的查询
SELECT column_value
  FROM my_table
 WHERE column_key LIKE "ABC%"

返回最少量的数据,sql引擎使用索引。