0

ANDロジックではなくORロジックを複製して従うrawQueryから結果を取得しています。つまり、「タキシード」を含むすべてのエントリと、「ホテル」を含むすべてのエントリを取得します。両方を含むもの。

これは私の方法です:

public ArrayList<Integer> getAdvancedResultIDList(String[] search)
{
    ArrayList<String> queryList = new ArrayList<String>();
    ArrayList<Integer> resultsList = new ArrayList<Integer>();
    SQLiteQueryBuilder builder = new SQLiteQueryBuilder();
    this.mDB = GamesList.mDBHelper.getDatabase();
    Cursor searchCursor = null;
    try
    {
        //TODO:
        // for each string in the search array search the whole of searchable table. Check that the results are only of the values that 
        // contain all the search strings, and add the id of that row to the results ArrayList
        for(int i = 0; i < search.length; i++)
        {
            String query;
            String s = '"' + search[i] + '"';
            query = "SELECT " + KEY_ID + " FROM "+ SEARCHABLE_TABLE + " WHERE " + SEARCHABLE_TABLE + " MATCH " + s;
            queryList.add(query);
        }

        String[] queryArray = queryList.toArray(new String[queryList.size()]);


        String unionQuery = builder.buildUnionQuery(queryArray, KEY_ID + " ASC", null);

        searchCursor = this.mDB.rawQuery(unionQuery, null);

        int colId = searchCursor.getColumnIndex(KEY_ID);

        String resultID;

        for(searchCursor.moveToFirst(); !searchCursor.isAfterLast();searchCursor.moveToNext())
        {
            resultID = searchCursor.getString(colId);
            Integer Id = Integer.parseInt(searchCursor.getString(colId));
            resultsList.add(Id);

        }
        searchCursor.close();

    }
    catch(Exception e)
    {
        e.printStackTrace();
    }
    finally
    {
        try
        {
            this.mDB.close();

        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
    }
    return resultsList;
}

明けましておめでとうございます。

4

1 に答える 1

0

ドキュメントでは、複数の検索語を使用する方法について説明しています。

SELECT id FROM searchTable WHERE searchTable MATCH 'tuxedo hotel'
于 2012-12-31T20:14:22.450 に答える