zoukankan      html  css  js  c++  java
  • 内容提供者

    一、继承ContentProvider

    package com.shz.provider;
    
    import com.shz.dao.SQLiteHelper;
    
    import android.content.ContentProvider;
    import android.content.ContentUris;
    import android.content.ContentValues;
    import android.content.UriMatcher;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.net.Uri;
    
    public class PersonProvider extends ContentProvider {
    
        private SQLiteHelper helper;
        private static UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH);
        private static final int INSERT = 1;
        private static final int DELETE = 2;
        private static final int UPDATE = 3;
        private static final int QUERY = 4;
        private static final int SINGLE = 5;
    
        static {
            matcher.addURI("db.personprovider", "insert", INSERT);
            matcher.addURI("db.personprovider", "delete", DELETE);
            matcher.addURI("db.personprovider", "update", UPDATE);
            matcher.addURI("db.personprovider", "query", QUERY);
            matcher.addURI("db.personprovider", "query/#", SINGLE);
        }
    
        @Override
        public boolean onCreate() {
            this.helper = new SQLiteHelper(getContext());
            return false;
        }
    
        @Override
        public Cursor query(Uri uri, String[] projection, String selection,
                String[] selectionArgs, String sortOrder) {
            if (matcher.match(uri) == QUERY) {
                SQLiteDatabase db = this.helper.getReadableDatabase();
                Cursor cursor = db.query("person", projection, selection,
                        selectionArgs, null, null, sortOrder);
                return cursor;
            } else if (matcher.match(uri) == SINGLE) {
                long id = ContentUris.parseId(uri);
                SQLiteDatabase db = this.helper.getReadableDatabase();
                Cursor cursor = db.query("person", projection, "id=?",
                        new String[] { String.valueOf(id) }, null, null, sortOrder);
                return cursor;
            } else {
                throw new IllegalArgumentException("Uri参数不匹配");
            }
        }
    
        @Override
        public String getType(Uri uri) {
            if (matcher.match(uri) == QUERY) {
                return "vnd.android.cursor.dir/person";
            } else if (matcher.match(uri) == SINGLE) {
                return "vnd.android.cursor.item/person";
            }
            return null;
        }
    
        @Override
        public Uri insert(Uri uri, ContentValues values) {
            if (matcher.match(uri) == INSERT) {
                SQLiteDatabase db = this.helper.getWritableDatabase();
                db.insert("person", null, values);
            }
    
            // 通知观察者数据已发生改变
            getContext().getContentResolver().notifyChange(uri, null);
            return uri;
        }
    
        @Override
        public int delete(Uri uri, String selection, String[] selectionArgs) {
            int result = 0;
            if (matcher.match(uri) == DELETE) {
                SQLiteDatabase db = this.helper.getWritableDatabase();
                result = db.delete("person", selection, selectionArgs);
            }
    
            // 通知观察者数据已发生改变
            getContext().getContentResolver().notifyChange(uri, null);
            return result;
        }
    
        @Override
        public int update(Uri uri, ContentValues values, String selection,
                String[] selectionArgs) {
            int result = 0;
            if (matcher.match(uri) == UPDATE) {
                SQLiteDatabase db = this.helper.getWritableDatabase();
                result = db.update("person", values, selection, selectionArgs);
            }
    
            // 通知观察者数据已发生改变
            getContext().getContentResolver().notifyChange(uri, null);
            return result;
        }
    
    }

    二、调用方法

    package com.shz.testprovider;
    
    import java.util.Random;
    
    import android.app.Activity;
    import android.content.ContentResolver;
    import android.content.ContentValues;
    import android.database.Cursor;
    import android.net.Uri;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    
    public class MainActivity extends Activity {
    
        private static final String TAG = "testprovider";
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
        }
    
        public void queryAll(View view) {
            ContentResolver resolver = this.getContentResolver();
            Uri uri = Uri.parse("content://db.personprovider/query");
            Cursor c = resolver.query(uri, null, null, null, null);
            while (c.moveToNext()) {
                Log.i(TAG, "姓名:" + c.getString(c.getColumnIndex("name")));
            }
    
            c.close();
        }
    
        public void querySingle(View view) {
            ContentResolver resolver = this.getContentResolver();
            Uri uri = Uri.parse("content://db.personprovider/query/7");
            Cursor c = resolver.query(uri, null, null, null, null);
            while (c.moveToNext()) {
                Log.i(TAG, "姓名:" + c.getString(c.getColumnIndex("name")));
            }
    
            c.close();
        }
    
        public void insert(View view) {
            ContentResolver resolver = this.getContentResolver();
            Uri uri = Uri.parse("content://db.personprovider/insert");
            ContentValues values = new ContentValues();
            Random rand = new Random();
            values.put("name", "shz" + rand.nextInt(100));
            values.put("gender", "男");
            values.put("account", rand.nextInt(10000));
            resolver.insert(uri, values);
        }
    
        public void update(View view) {
            ContentResolver resolver = this.getContentResolver();
            Uri uri = Uri.parse("content://db.personprovider/update");
            ContentValues values = new ContentValues();
            Random rand = new Random();
            values.put("name", "dhf" + rand.nextInt(100));
            values.put("gender", "女");
            values.put("account", rand.nextInt(10000));
            resolver.update(uri, values, "id=1", new String[] { 5 + "" });
        }
    
        public void delete(View view) {
            ContentResolver resolver = this.getContentResolver();
            Uri uri = Uri.parse("content://db.personprovider/delete");
            Random rand = new Random();
            resolver.delete(uri, "id=?", new String[] { rand.nextInt(10) + "" });
        }
    
    }

     三、AndroidManifest清单文件

    <instrumentation
            android:name="android.test.InstrumentationTestRunner"
            android:targetPackage="com.shz.db" />
    
    <application
            android:allowBackup="true"
            android:icon="@drawable/ic_launcher"
            android:label="@string/app_name"
            android:theme="@style/AppTheme" >
            <uses-library android:name="android.test.runner" />
    
            <activity
                android:name="com.shz.db.MainActivity"
                android:label="@string/app_name" >
                <intent-filter>
                    <action android:name="android.intent.action.MAIN" />
    
                    <category android:name="android.intent.category.LAUNCHER" />
                </intent-filter>
            </activity>
    
            <provider
                android:name="com.shz.provider.PersonProvider"
                android:authorities="db.personprovider"
                android:exported="true" >
            </provider>
        </application>
  • 相关阅读:
    spring的@Transactional注解详细用法
    java中线程池的使用方法
    Java中多线程使用匿名内部类的方式进行创建3种方式
    RISC-V指令集的诞生,"V"也表示变化(variation)和向量(vectors)
    雷军致全员公开信:明天,让我们一起见证伟大时刻!(估值543亿美元,中国的山寨机已被彻底消灭,通过生态链产品改变了100多个行业,全面推动了商业效率的提升,上市仅仅是小米新的开始)
    C语言利用 void 类型指针实现面向对象类概念与抽象
    Google、Mozilla、Qt、LLVM 这几家的规范是明确禁用异常的
    Qt程序调试之Q_ASSERT断言(它是一个宏,接受布尔值,当其中的布尔值为真时,便什么也不做)
    ES 1.7安装ik分词elasticsearch-analysis-ik-1.2.5中文同义词实现
    Windows 64下elasticsearch-1.7.1集群 安装、启动、停止
  • 原文地址:https://www.cnblogs.com/shaomenghao/p/3905754.html
Copyright © 2011-2022 走看看