zoukankan      html  css  js  c++  java
  • contentProvider模板

    package com.example.qunzheng.todolist.provider;
    
    import android.content.ContentProvider;
    import android.content.ContentUris;
    import android.content.ContentValues;
    import android.content.Context;
    import android.content.UriMatcher;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteOpenHelper;
    import android.database.sqlite.SQLiteQueryBuilder;
    import android.net.Uri;
    import android.text.TextUtils;
    
    /**
     * Created by QunZheng on 2015/3/9.
     */
    public class EarthquakeProvider extends ContentProvider {
        public static final Uri CONTENT_URI = Uri.parse("content://com.qunzheng.earthquakeprovider/earthquakes");
        public static final String KEY_ID = "_id";
        public static final String KEY_DATE = "date";
        public static final String KEY_DETAILS = "details";
        public static final String KEY_SUMMARY = "summary";
        public static final String KEY_LOCATION_LAT = "latitude";
        public static final String KEY_LOCATION_LNG = "longitude";
        public static final String KEY_LINK = "link";
        public static final String KEY_MAGNITUDE = "magnitude";
    
        private EarthquakeDatabaseHelper sqLiteOpenHelper = null;
    
        private static final int ALL_ROWS = 1;
        private static final int SINGLE_ROW = 2;
    
        private static UriMatcher matcher = null;
    
        static {
            matcher = new UriMatcher(UriMatcher.NO_MATCH);
            matcher.addURI("com.qunzheng.earthquakeprovider","earthquakes",ALL_ROWS);
            matcher.addURI("com.qunzheng.earthquakeprovider","earthquakes/#",SINGLE_ROW);
        }
    
        @Override
        public boolean onCreate() {
            sqLiteOpenHelper = new EarthquakeDatabaseHelper(getContext(), EarthquakeDatabaseHelper.DATABASE_NAME, null, EarthquakeDatabaseHelper.DATABASE_VERSION);
            return true;
        }
    
        @Override
        public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
            SQLiteDatabase db = sqLiteOpenHelper.getWritableDatabase();
    
            SQLiteQueryBuilder queryBuilder = new SQLiteQueryBuilder();
            queryBuilder.setTables(EarthquakeDatabaseHelper.DATABASE_TABLE);
            switch (matcher.match(uri)) {
                case SINGLE_ROW:
                    String rowId = uri.getPathSegments().get(1);
                    queryBuilder.appendWhere(KEY_ID + "=" + rowId);
                    break;
            }
    
            String orderBy;
            if (TextUtils.isEmpty(sortOrder)) {
                orderBy = KEY_DATE;
            }else{
                orderBy = sortOrder;
            }
            return queryBuilder.query(db,projection,selection,selectionArgs,null,null,orderBy);
        }
    
        @Override
        public String getType(Uri uri) {
            switch (matcher.match(uri)) {
                case ALL_ROWS:
                    return "vnd.android.cursor.dir/vnd.qunzheng.earthquakes";
                case SINGLE_ROW:
                    return "vnd.android.cursor.item/vnd.qunzheng.earthquakes";
                default:
                    throw new IllegalArgumentException("Unsupport Uri:" + uri);
            }
        }
    
        @Override
        public Uri insert(Uri uri, ContentValues values) {
            SQLiteDatabase db = sqLiteOpenHelper.getWritableDatabase();
    
            long id = db.insert(EarthquakeDatabaseHelper.DATABASE_TABLE, null, values);
    
            //数据插入成功
            if (id > -1) {
                Uri resultUri = ContentUris.withAppendedId(CONTENT_URI, id);
    
                getContext().getContentResolver().notifyChange(resultUri, null);
                return resultUri;
            }else{
    
            }
            return null;
        }
    
        @Override
        public int delete(Uri uri, String selection, String[] selectionArgs) {
            SQLiteDatabase db = sqLiteOpenHelper.getWritableDatabase();
    
            switch (matcher.match(uri)) {
                case SINGLE_ROW:
                    String id = uri.getPathSegments().get(1);
                    selection = KEY_ID + "=" + id +
                            (TextUtils.isEmpty(selection) ? "" : (" and ("+ selection +")"));
                    break;
            }
    
            if (selection == null) {
                selection = "1";
            }
    
            int resultRows = db.delete(EarthquakeDatabaseHelper.DATABASE_TABLE, selection, selectionArgs);
    
            getContext().getContentResolver().notifyChange(uri, null);
            return resultRows;
        }
    
        @Override
        public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
            SQLiteDatabase db = sqLiteOpenHelper.getReadableDatabase();
    
            switch (matcher.match(uri)) {
                case SINGLE_ROW:
                    String id = uri.getPathSegments().get(1);
                    selection = KEY_ID + "=" + id +
                            (TextUtils.isEmpty(selection) ? "" : (" and ("+ selection +")"));
                    break;
            }
    
            int resultRows = db.update(EarthquakeDatabaseHelper.DATABASE_TABLE, values, selection, selectionArgs);
            getContext().getContentResolver().notifyChange(uri, null);
            return resultRows;
        }
    
        private static class EarthquakeDatabaseHelper extends SQLiteOpenHelper{
    
            public static final String DATABASE_NAME = "earthquake.db";
            public static final int DATABASE_VERSION = 1;
            public static final String DATABASE_TABLE = "earthQuake";
    
            private static final String TABLE_CREATE = "create table " +
                    DATABASE_TABLE + " (" + KEY_ID + " integer primary key autoincrement, " +
                    KEY_DATE + " INTEGER, " +
                    KEY_LINK + " text, " +
                    KEY_LOCATION_LAT + " FLOAT, " +
                    KEY_LOCATION_LNG + " FLOAT, " +
                    KEY_SUMMARY + " TEXT, " +
                    KEY_MAGNITUDE + " FLOAT, " +
                    KEY_DETAILS + " text)";
    
    
    
            public EarthquakeDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
                super(context, name, factory, version);
            }
    
            @Override
            public void onCreate(SQLiteDatabase db) {
                db.execSQL(TABLE_CREATE);
            }
    
            @Override
            public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    
            }
        }
    }
    

      

  • 相关阅读:
    我的第一篇博客
    吴裕雄--天生自然python学习笔记:Python3 标准库概览
    吴裕雄--天生自然python学习笔记:Python3 命名空间和作用域
    吴裕雄--天生自然python学习笔记:Python3 面向对象
    吴裕雄--天生自然python学习笔记:Python3 错误和异常
    吴裕雄--天生自然python学习笔记:Python3 OS 文件/目录方法
    吴裕雄--天生自然python学习笔记:Python3 File(文件) 方法
    吴裕雄--天生自然python学习笔记:Python3 输入和输出
    吴裕雄--天生自然python学习笔记:Python3 模块
    吴裕雄--天生自然python学习笔记:Python3 数据结构
  • 原文地址:https://www.cnblogs.com/zhengqun/p/4358021.html
Copyright © 2011-2022 走看看