Android Sqlite搜索查询与WHERE,AND,OR子句

时间:2018-05-18 05:14:10

标签: java android android-sqlite android-cursor android-query

在这里,我需要从'TABLE_NAME'表格'COLUMN_NAME_COUNTRY' = country 'AND' 'COLUMN_NAME_CATEGORY' = local 'OR' NA (Na also a value in the 'COLUMN_NAME_CATEGORY'获取结果。以下是我的代码:

public List<AppDataBean>getAllDataForSelectedCountryWithCategory(String country){

        ArrayList<AppDataBean>dataList= new ArrayList<>();
        SQLiteDatabase db = AppDbHelper.getInstance(context).getWritableDatabase();
        dataList.clear();

        try {
            Cursor c = db.rawQuery("SELECT * FROM " + AppDbConstructor.AppData.TABLE_NAME + " WHERE " + AppDbConstructor.AppData.COLUMN_NAME_COUNTRY + "='" + country + "'"
                    + " AND " + AppDbConstructor.AppData.COLUMN_NAME_CATEGORY + "='" + "Local" + "'" + " OR " + AppDbConstructor.AppData.COLUMN_NAME_CATEGORY + "='" + "NA" + "'" , null);

            if (c.getCount()>0)
            {
                if (c.moveToFirst())
                {
                    for (int i=0; i<c.getCount(); i++)
                    {
                        AppDataBean appDataBean = new AppDataBean();
                        appDataBean.setCategory(c.getString(c.getColumnIndex(AppDbConstructor.AppData.COLUMN_NAME_CATEGORY)));
                        appDataBean.setUrl(c.getString(c.getColumnIndex(AppDbConstructor.AppData.COLUMN_NAME_URL)));
                        appDataBean.setSource(c.getString(c.getColumnIndex(AppDbConstructor.AppData.COLUMN_NAME_SOURCE)));
                        appDataBean.setIconUrl(c.getString(c.getColumnIndex(AppDbConstructor.AppData.COLUMN_NAME_ICON_URL)));
                        appDataBean.setCountry(c.getString(c.getColumnIndex(AppDbConstructor.AppData.COLUMN_NAME_COUNTRY)));
                        Log.d("APP_DB_SOURCE","COLUMN_NAME_SOURCE: "+ c.getString(c.getColumnIndex(AppDbConstructor.AppData.COLUMN_NAME_URL))
                                + ", " + c.getString(c.getColumnIndex(AppDbConstructor.AppData.COLUMN_NAME_CATEGORY)));

                        dataList.add(appDataBean);
                        Log.d("APPDBSOURCE", "LIST_VALUES_ARE" + dataList.get(i).getCategory() + ", " + dataList.get(i).getCountry());
                        c.moveToNext();
                    }
                }
            }
            c.close();
        }catch (Exception e){
            e.printStackTrace();
        }
        finally
        {
            db.close();
        }

        return dataList;
    }

最后,结果为“所有国家/地区”,并带有“本地”类别。

1 个答案:

答案 0 :(得分:1)

您缺少括号。

你可以这样做:

Cursor c = db.rawQuery("SELECT * FROM " + AppDbConstructor.AppData.TABLE_NAME + " WHERE " + AppDbConstructor.AppData.COLUMN_NAME_COUNTRY + "='" + country + "'"
                    + " AND (" + AppDbConstructor.AppData.COLUMN_NAME_CATEGORY + "='" + "Local" + "'" + " OR " + AppDbConstructor.AppData.COLUMN_NAME_CATEGORY + "='" + "NA" + "')" , null);

或者像这样:

Cursor c = db.rawQuery("SELECT * FROM " + AppDbConstructor.AppData.TABLE_NAME + " WHERE " + AppDbConstructor.AppData.COLUMN_NAME_COUNTRY + "='" + country + "'"
                    + " AND " + AppDbConstructor.AppData.COLUMN_NAME_CATEGORY + " IN " + "('"+ "Local"+"','"+"NA" + "')" , null);