zoukankan      html  css  js  c++  java
  • Android之自定义contentprovider

    1、ContentProviderTestActivity 类中有2个按钮,分别插入数据为查询数据

    2、DataBaseConfiguation 为程序所用到的配置信息 注:TableConfiguation内部类实现BaseColumns,即声明了_ID 和 _COUNT

    3、MyContentProvider 自定义ContentProvider,继承与ContentProvider

    其中 uriMatcher 为Uri的匹配器,在静态块中初始化URI。 columnMap为表结构的映射mapping

    在getType方法中要根据访问的Uri确定访问资源的类型,以字符串形式返回。
    格式为:"vnd.android.cursor.dir/vnd.catking.userList"、"vnd.android.cursor.item/vnd.catking.userItem";

    注释掉,对程序运行无影响。

    注意:

    static{

      //初始化URI
      uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
      uriMatcher.addURI(DataBaseConfiguation.AUTHORITY, "user", USER_LIST_CODE);
      uriMatcher.addURI(DataBaseConfiguation.AUTHORITY, "user/#", USER_RECORD_CODE);
       红色字体中,的格式为xxx/xx,并不是/xxx/xx,其中*号匹配所有字符,#匹配所有数字
      //表结构的映射
      columnMap.put(DataBaseConfiguation.TableConfiguation._ID, DataBaseConfiguation.TableConfiguation._ID);
      columnMap.put(DataBaseConfiguation.TableConfiguation.USER_NAME, DataBaseConfiguation.TableConfiguation.USER_NAME);
     }

     

    最后在AndroidManifest.xml里配上

    <provider android:authorities="com.catking.contentprovider.MyContentProvider" android:name="com.catking.contentprovider.MyContentProvider" />

    authorities的值必须与DataBaseConfiguation.AUTHORITY一致 

    ContentProviderTestActivity:

    import android.app.Activity;
    import android.content.ContentValues;
    import android.database.Cursor;
    import android.net.Uri;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;

    import com.catking.cfg.DataBaseConfiguation;

    public class ContentProviderTestActivity extends Activity {
        private Button insertBtn;
        private Button queryBtn;
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);
            
            insertBtn = (Button) findViewById(R.id.insert);
            queryBtn = (Button) findViewById(R.id.query);
            
            insertBtn.setOnClickListener(new InsertOnClickListener());
            queryBtn.setOnClickListener(new QueryOnClickListener());
        }
        
        class InsertOnClickListener implements OnClickListener{
            @Override
            public void onClick(View v) {
                ContentValues values = new ContentValues();
                values.put(DataBaseConfiguation.TableConfiguation.USER_NAME, "张三");
                Uri uri = getContentResolver().insert(DataBaseConfiguation.TableConfiguation.CONTENT_URI, values);
                System.out.println("uri------------------->" + uri);
            }
        }
        
        class QueryOnClickListener implements OnClickListener{
            @Override
            public void onClick(View v) {
                Cursor cursor = getContentResolver().query(DataBaseConfiguation.TableConfiguation.CONTENT_URI,
                        nullnullnullnull);
                while (cursor.moveToNext()) {
                    System.out.println(cursor.getString(cursor.getColumnIndex(DataBaseConfiguation.TableConfiguation.USER_NAME)));
                }
            }
            
        }
    }


    DataBaseConfiguation:

    package com.catking.cfg;

    import android.net.Uri;
    import android.provider.BaseColumns;

    public class DataBaseConfiguation {
        public static final String AUTHORITY = "com.catking.contentprovider.MyContentProvider";
        public static final String DATABASE_NAME = "cp_db";
        public static final int DATABASE_VERSION = 1;
        
        public static class TableConfiguation implements BaseColumns{
            public static final String TABLE_NAME = "user";
            public static final Uri CONTENT_URI = Uri.parse("content://" + DataBaseConfiguation.AUTHORITY + "/" + TABLE_NAME);
            public static final String CONTENT_TYPE_DIR = "vnd.android.cursor.dir/vnd.catking.userList";
            public static final String CONTENT_TYPE_RECORD = "vnd.android.cursor.item/vnd.catking.userItem";
            public static final String USER_NAME = "name";
            public static final String DEFAULT_SORT_ORDER = "_id desc";
        }


    MyContentProvider:

    public class MyContentProvider extends ContentProvider {
        
        private static final UriMatcher uriMatcher;
        private static final int USER_LIST_CODE = 1;
        private static final int USER_RECORD_CODE = 2;
        private SQLiteOpenHelper dbh;
        private static Map<String, String> columnMap = new HashMap<String, String>();
        
        static{
            uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
            uriMatcher.addURI(DataBaseConfiguation.AUTHORITY, "user", USER_LIST_CODE);
            uriMatcher.addURI(DataBaseConfiguation.AUTHORITY, "user/#", USER_RECORD_CODE);
            
            
            columnMap.put(DataBaseConfiguation.TableConfiguation._ID, DataBaseConfiguation.TableConfiguation._ID);
            columnMap.put(DataBaseConfiguation.TableConfiguation.USER_NAME, DataBaseConfiguation.TableConfiguation.USER_NAME);
        }
        
        @Override
        public boolean onCreate() {
            dbh = new MySQLiteOpenHelper(getContext(), DataBaseConfiguation.DATABASE_NAME, null, DataBaseConfiguation.DATABASE_VERSION);
            System.out.println("dbh ������");
            return true;
        }

        @Override
        public String getType(Uri uri) {
            System.out.println("getTypeִ��");
            switch (uriMatcher.match(uri)) {
            case USER_LIST_CODE:
                return DataBaseConfiguation.TableConfiguation.CONTENT_TYPE_DIR;
            case USER_RECORD_CODE:
                return DataBaseConfiguation.TableConfiguation.CONTENT_TYPE_RECORD;
            default:
                throw new RuntimeException("unknown uri " + uri.toString());
            }
        }

        @Override
        public Uri insert(Uri uri, ContentValues values) {
            System.out.println("insert ִ��");
            SQLiteDatabase db = dbh.getWritableDatabase();
            long rowId = db.insert(DataBaseConfiguation.TableConfiguation.TABLE_NAME, null, values);
            if (rowId > 0) {
                Uri insertedUri = ContentUris.withAppendedId(DataBaseConfiguation.TableConfiguation.CONTENT_URI, rowId);
                getContext().getContentResolver().notifyChange(insertedUri, null);
                return insertedUri;
            }
            throw new SQLException("fail to insert row into " + uri.toString());
        }

        @Override
        public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
            System.out.println(DataBaseConfiguation.TableConfiguation.CONTENT_URI);
            SQLiteDatabase db = dbh.getReadableDatabase();
            SQLiteQueryBuilder qb = new SQLiteQueryBuilder();
            qb.setTables(DataBaseConfiguation.TableConfiguation.TABLE_NAME);
            qb.setProjectionMap(columnMap);
            switch (uriMatcher.match(uri)) {
            case USER_LIST_CODE:
                break;
            case USER_RECORD_CODE:
                System.out.println("��ʼ��ѯuri.getPathSegments()����");
                for (String s : uri.getPathSegments()) {
                    System.out.println(s);
                }
                System.out.println("�����ѯuri.getPathSegments()����");
                qb.appendWhere(DataBaseConfiguation.TableConfiguation.USER_NAME + "=" + uri.getPathSegments().get(1));
                break;
            default:
                throw new RuntimeException("unknown uri " + uri.toString());
            }
            Cursor c = db.query(DataBaseConfiguation.TableConfiguation.TABLE_NAME, projection, selection, selectionArgs, nullnull,
                    DataBaseConfiguation.TableConfiguation.DEFAULT_SORT_ORDER);
            c.setNotificationUri(getContext().getContentResolver(), uri);
            return c;
        }

        @Override
        public int delete(Uri uri, String selection, String[] selectionArgs) {
            // TODO Auto-generated method stub
            return 0;
        }

        @Override
        public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
            // TODO Auto-generated method stub
            return 0;
        }
    }  

    MySQLiteOpenHelper:

    public class MySQLiteOpenHelper extends SQLiteOpenHelper {

        public MySQLiteOpenHelper(Context context, String name, CursorFactory factory, int version) {
            super(context, name, factory, version);
        }

        @Override
        public void onCreate(SQLiteDatabase db) {
            System.out.println("createDB excuted");
            String createSQL = "create table " + DataBaseConfiguation.TableConfiguation.TABLE_NAME + "("
                    + DataBaseConfiguation.TableConfiguation._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, "
                    + DataBaseConfiguation.TableConfiguation.USER_NAME + " VARCHAR(20)" + ")";
            System.out.println(createSQL);
            db.execSQL(createSQL);
        }

        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            System.out.println("onUpgrade excuted");
        }
    }  


    AndroidManifest:

    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.catking.activity"
        android:versionCode="1"
        android:versionName="1.0" >

        <uses-sdk android:minSdkVersion="8" />

        <application
            android:icon="@drawable/ic_launcher"
            android:label="@string/app_name" >
            <activity
                android:name=".ContentProviderTestActivity"
                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:authorities="com.catking.contentprovider.MyContentProvider" android:name="com.catking.contentprovider.MyContentProvider" />
        </application>
    </manifest>  


    参考自:http://catkingwong.iteye.com/blog/1313740 

  • 相关阅读:
    微信端video去除最顶层播放
    MVC错误页面相关说明
    sublime使用
    linux或Mac下手动回滚代码
    用Python操作git命令
    利用pyinstaller打包加密Python项目
    进程、线程和协程的结合使用
    模块导入失败问题
    递归调用解压zip包或rar包
    随机验证码&发红包
  • 原文地址:https://www.cnblogs.com/lee0oo0/p/2659794.html
Copyright © 2011-2022 走看看