使用SimpleCursorAdapter Android过滤类别

时间:2013-08-18 02:23:59

标签: android sql select

我不确定为什么过滤不起作用。我见过很多例子,但游标非常特别。

我有一个基于数据库的项目的一般列表。列是_ID,类别,标题和内容。

在类别下,有两种类型:注意和待办事项。

所以,我的应用程序上有3个ListViews,一个用于所有项目,一个用于笔记,另一个用于待办事项。

为了填充笔记列表,我有这个方法:

private void fillNotesData() {


    final ContentResolver resolver = getContentResolver();
    final String[] projection = { Notero_Table.COLUMN_ID, 
                                   Notero_Table.NOTE_CATEGORY,  
                                   Notero_Table.NOTE_TITLE,
                                   Notero_Table.NOTE_CONTENT };
    final String mSelectionArgs = "%Note%";
    mCursorForNotes = resolver.query(Notero_Provider.CONTENT_URI, 
                                    projection, 
                                    Notero_Table.NOTE_CATEGORY + " LIKE ?", 
                                    new String[] { mSelectionArgs }, 
                                    null);

    String[] from = new String[] { Notero_Table.NOTE_TITLE, Notero_Table.NOTE_CONTENT };
    int[] to = new int[] { R.id.text_row, R.id.text_row_two };

    getLoaderManager().initLoader(0, null, this);
    mAdapter = new SimpleCursorAdapter(this, 
                                        R.layout.row, 
                                        mCursorForNotes, 
                                        from, 
                                        to, 
                                        0);
    setListAdapter(mAdapter);
}

已创建活动列表,但根本没有过滤器。 mCursorForNotes的查询有问题。

任何帮助?

感谢。

1 个答案:

答案 0 :(得分:0)

这是表类

public class Notero_Table {

private final static String TAG = "Notero_Table";

public static final String TABLE_NOTERO = "note";
public static final String COLUMN_ID = "_id";
public static final String NOTE_CATEGORY = "category";
public static final String NOTE_TITLE = "title";
public static final String NOTE_CONTENT = "content";

private static final String DATABASE_CREATE = "CREATE TABLE " 
                            + TABLE_NOTERO 
                            + "(" + COLUMN_ID + " integer primary key autoincrement, "
                                  + NOTE_CATEGORY + " text not null, "
                                  + NOTE_TITLE + " text not null, "
                                  + NOTE_CONTENT + " text not null " + ");";

public static void onCreate(SQLiteDatabase database) {

    database.execSQL(DATABASE_CREATE);
    Log.d(TAG, "***** Se crea base de datos *****");
}

public static void onUpgrade(SQLiteDatabase database, int oldVersion, int newVersion) {
    Log.w(NoteEdit.class.getName(), "Upgrading database version from version " + oldVersion 
            + " to " + newVersion + ", which will destroy all old data");
    database.execSQL("DROP TABLE IF EXISTS " + TABLE_NOTERO);
    onCreate(database);
}

}

这是DataBase OpenHelper。

public class Notero_DBHelper extends SQLiteOpenHelper {

private static final String DATABASE_NAME = "notero.db";
private static final int DATABASE_VERSION = 3;

public Notero_DBHelper(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

@Override
public void onCreate(SQLiteDatabase database) {
    Notero_Table.onCreate(database);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    Notero_Table.onUpgrade(db, oldVersion, newVersion);

}

}

以防万一,这是提供者:

public class Notero_Provider extends ContentProvider {

private Notero_DBHelper database;
private static final int ALL_ITEMS = 10;
private static final int ITEM_ID = 20;


private static final String AUTHORITY = "com.dominicapps.notero.Notero_Provider";
private static final String BASE_PATH = "items";
public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/" + BASE_PATH);
public static final String CONTENT_TYPE = ContentResolver.CURSOR_DIR_BASE_TYPE + "/items";
public static final String CONTENT_ITEM_TYPE = ContentResolver.CURSOR_ITEM_BASE_TYPE + "/item";

private static final UriMatcher sUriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
    static {
        sUriMatcher.addURI(AUTHORITY, BASE_PATH, ALL_ITEMS);
        sUriMatcher.addURI(AUTHORITY, BASE_PATH + "/#", ITEM_ID);
}

@Override
public boolean onCreate() {
    database = new Notero_DBHelper(getContext());
    return false;
}

@Override
public Cursor query(Uri uri, String[] projection, String selection,
        String[] selectionArgs, String sortOrder) {

    SQLiteQueryBuilder queryBuilder = new SQLiteQueryBuilder();
    CheckColumns(projection);
    queryBuilder.setTables(Notero_Table.TABLE_NOTERO);
    int UriType = sUriMatcher.match(uri);
    switch (UriType) {
    case ALL_ITEMS:
        break;
    case ITEM_ID:
        queryBuilder.appendWhere(Notero_Table.COLUMN_ID + "="
                + uri.getLastPathSegment());
        break;

    default:
        throw new IllegalArgumentException("Unknown URI: " + uri);
    }

    SQLiteDatabase db = database.getWritableDatabase();
    Cursor cursor = queryBuilder.query(db, projection, selection,
            selectionArgs, null, null, sortOrder);
    cursor.setNotificationUri(getContext().getContentResolver(), uri);
    return cursor;

}

@Override
public String getType(Uri uri) {
    return null;
}

@Override
public Uri insert(Uri uri, ContentValues values) {
    int uriType = sUriMatcher.match(uri);
    SQLiteDatabase sqlDB = database.getWritableDatabase();
    int rowsDeleted = 0;
    long id = 0;
    switch (uriType) {
    case ALL_ITEMS:
        id = sqlDB.insert(Notero_Table.TABLE_NOTERO, null, values);
        break;
    default:
        throw new IllegalArgumentException("Uri desconocido: " + uri);
    }
    getContext().getContentResolver().notifyChange(uri, null);
    return Uri.parse(BASE_PATH + "/" + id);
}

@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
    int uriType = sUriMatcher.match(uri);
    SQLiteDatabase sqlDB = database.getWritableDatabase();
    int rowsDeleted = 0;
    switch (uriType) {
    case ALL_ITEMS:
        rowsDeleted = sqlDB.delete(Notero_Table.TABLE_NOTERO, selection,
                selectionArgs);
        break;
    case ITEM_ID:
        String id = uri.getLastPathSegment();
        if (TextUtils.isEmpty(selection)) {
            rowsDeleted = sqlDB.delete(Notero_Table.TABLE_NOTERO,
                    Notero_Table.COLUMN_ID + "=" + id, 
                    null);
        } else {
            rowsDeleted = sqlDB.delete(Notero_Table.TABLE_NOTERO, 
                    Notero_Table.COLUMN_ID + "=" + id + " and " + selection, 
                    selectionArgs);
        }
        break;
    default:
        throw new IllegalArgumentException("Unknown URI: " + uri);
    }
    getContext().getContentResolver().notifyChange(uri, null);
    return rowsDeleted;
}

@Override
public int update(Uri uri, ContentValues values, String selection,
        String[] selectionArgs) {

    int uriType = sUriMatcher.match(uri);
    SQLiteDatabase sqlDB = database.getWritableDatabase();
    int rowsUpdated = 0;
    switch (uriType) {
    case ALL_ITEMS:
        rowsUpdated = sqlDB.update(Notero_Table.TABLE_NOTERO, 
                values, 
                selection,
                selectionArgs);
        break;
    case ITEM_ID:
        String id = uri.getLastPathSegment();
        if (TextUtils.isEmpty(selection)) {
            rowsUpdated = sqlDB.update(Notero_Table.TABLE_NOTERO, 
                    values,
                    Notero_Table.COLUMN_ID + "=" + id, 
                    null);
        } else {
            rowsUpdated = sqlDB.update(Notero_Table.TABLE_NOTERO, 
                    values,
                    Notero_Table.COLUMN_ID + "=" + id 
                    + "and" 
                    + selection,
                    selectionArgs);
        }
        break;
    default:
        throw new IllegalArgumentException("Unknown URI: " + uri);
    }
    getContext().getContentResolver().notifyChange(uri, null);
    return rowsUpdated;
}

private void CheckColumns(String[] projection) {
    String[] available = { 
            Notero_Table.NOTE_CATEGORY,
            Notero_Table.NOTE_TITLE, 
            Notero_Table.NOTE_CONTENT,
            Notero_Table.COLUMN_ID };
    if (projection != null) {
        HashSet<String> requestedColumns = new HashSet<String>(
                Arrays.asList(available));
        HashSet<String> availableColumns = new HashSet<String>(
                Arrays.asList(available));
        if (!availableColumns.containsAll(requestedColumns)) {
            throw new IllegalArgumentException("Unknown columns in projection");
        }
    }
}
}

再次感谢。