Android使用内容提供者方式进行存储


内容提供者(ContentProvider)主要作用是对外共享数据,如果数据通过内容提供者对外共享了,那么其他应用就可以从内容提供者中查询到数据,并且可更新数据、删除数据、添加数据,如果采用文件的操作模式对外共享数据,数据的访问方式会因为存储方式的不同导致数据的访问方式无法得到统一,不同存储方式文件对外进行共享其访问的ApI是不一样的,如果采用内容提供者对外共享数据就会统一了数据的访问方式。采用统一的API访问共享的数据。

创建内容提供者步骤

1.创建内容提供者需要继承Android.content.ContentProvider

2.清单文件中进行配置:

   <!--android:name:指定内容提供者的类名,android:authorities:调用内容..名称,随意取  -->
   <provider android:name=".PersonProvider" android:authorities="cn.test.providers.personprovider"/>

ContentProvider类主要方法

public boolean onCreate()

该方法在ContentProvider创建后就会被调用, Android开机后, ContentProvider在其它应用第一次访问它时才会被创建。

public Uriinsert(Uri uri, ContentValues values)

该方法用于供外部应用往ContentProvider添加数据。

public int delete(Uri uri, String selection,String[] selectionArgs)

该方法用于供外部应用从ContentProvider删除数据。

public int update(Uri uri, ContentValues values, Stringselection, String[] selectionArgs)

该方法用于供外部应用更新ContentProvider中的数据。

public Cursorquery(Uri uri, String[]projection, String selection, String[] selectionArgs, String sortOrder)

该方法用于供外部应用从ContentProvider中获取数据。


示例:

内容提供者类,实现数据的增删改查

  1. public class PersonProvider extends ContentProvider {  
  2.     //创建工具类实现Uri匹配  
  3.     private static final UriMatcher MATCHER = new UriMatcher(UriMatcher.NO_MATCH);  
  4.     private static final int PERSONS = 1;  
  5.     private static final int PERSON = 2;  
  6.     static{  
  7.         MATCHER.addURI("cn.test.providers.personprovider", "person", PERSONS);  
  8.         MATCHER.addURI("cn.test.providers.personprovider", "person/#", PERSON);  
  9.     }  
  10.     private DBOpenHelper dbOpenHelper = null;  
  11.       
  12.     @Override  
  13.     public boolean onCreate() {  
  14.         dbOpenHelper = new DBOpenHelper(getContext());  
  15.         return true;  
  16.     }  
  17.       
  18.     @Override  
  19.     public Cursor query(Uri uri, String[] projection, String selection,  
  20.             String[] selectionArgs, String sortOrder) {  
  21.         SQLiteDatabase db = dbOpenHelper.getReadableDatabase();  
  22.         switch (MATCHER.match(uri)) {  
  23.         case PERSONS: // 获取person表中的所有数据   /person  
  24.             return db.query("person", projection, selection, selectionArgs, null, null, sortOrder);  
  25.               
  26.         case PERSON: // 获取person表中的指定id的数据 /person/20  
  27.             long id = ContentUris.parseId(uri);  
  28.             String where = "personid="+ id;  
  29.             if(selection!=null && !"".equals(selection.trim())){  
  30.                 where += " and "+ selection;  
  31.             }  
  32.             return db.query("person", projection, where, selectionArgs, null, null, sortOrder);  
  33.         default:  
  34.             throw new IllegalArgumentException("Unknown Uri:"+ uri);  
  35.         }  
  36.     }  
  37.   
  38.     @Override  
  39.     public String getType(Uri uri) {  
  40.         // TODO Auto-generated method stub  
  41.         return null;  
  42.     }  
  43.   
  44.     @Override  
  45.     public Uri insert(Uri uri, ContentValues values) {  
  46.         //取得数据库操作实例  
  47.         SQLiteDatabase db = dbOpenHelper.getWritableDatabase();  
  48.         switch (MATCHER.match(uri)) {  
  49.         case PERSONS:  
  50.             //执行添加,返回行号,如果主健字段是自增长的,那么行号会等于主键id  
  51.             long rowid = db.insert("person", "name", values);   
  52.             //得到拼好的uri  
  53.             Uri insertUri = ContentUris.withAppendedId(uri, rowid);  
  54.             //发出数据变化通知(person表的数据发生变化)  
  55.             getContext().getContentResolver().notifyChange(uri, null);  
  56.             return insertUri;  
  57.         default:  
  58.             //不能识别uri  
  59.             throw new IllegalArgumentException("Unknown Uri:"+ uri);  
  60.         }  
  61.     }  
  62.   
  63.     @Override  
  64.     public int delete(Uri uri, String selection, String[] selectionArgs) {  
  65.         SQLiteDatabase db = dbOpenHelper.getWritableDatabase();  
  66.         //受影响的行数  
  67.         int num = 0;  
  68.         switch (MATCHER.match(uri)) {  
  69.         case PERSONS: // 删除person表中的所有数据   /person  
  70.             num = db.delete("person", selection, selectionArgs);  
  71.             break;  
  72.               
  73.         case PERSON: // 删除person表中的指定id的数据 /person/20  
  74.             long id = ContentUris.parseId(uri);  
  75.             String where = "personid="+ id;  
  76.             if(selection!=null && !"".equals(selection.trim())){  
  77.                 where += " and "+ selection;  
  78.             }  
  79.             num = db.delete("person", where, selectionArgs);  
  80.             break;  
  81.         default:  
  82.             throw new IllegalArgumentException("Unknown Uri:"+ uri);  
  83.         }  
  84.         return num;  
  85.     }  
  86.   
  87.     @Override  
  88.     public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {  
  89.         SQLiteDatabase db = dbOpenHelper.getWritableDatabase();  
  90.         int num = 0;  
  91.         switch (MATCHER.match(uri)) {  
  92.         case PERSONS: // 更新person表中的所有数据   /person  
  93.             num = db.update("person", values, selection, selectionArgs);  
  94.             break;  
  95.               
  96.         case PERSON: // 更新person表中的指定id的数据 /person/20  
  97.             long id = ContentUris.parseId(uri);  
  98.             String where = "personid="+ id;  
  99.             if(selection!=null && !"".equals(selection.trim())){  
  100.                 where += " and "+ selection;  
  101.             }  
  102.             num = db.update("person", values, where, selectionArgs);  
  103.             break;  
  104.         default:  
  105.             throw new IllegalArgumentException("Unknown Uri:"+ uri);  
  106.         }  
  107.         return num;  
  108.     }  
  109. }  

其他工程中访问:

  1. public class AccessContentProiderTest extends AndroidTestCase {  
  2.   
  3.     public void testInsert() throws Throwable{  
  4.         ContentResolver resolver = getContext().getContentResolver();  
  5.         Uri uri = Uri.parse("content://cn.test.providers.personprovider/person");  
  6.         ContentValues values = new ContentValues();  
  7.         values.put("name", "lili");  
  8.         values.put("phone", "110");  
  9.         values.put("amount", "3000000000");  
  10.         resolver.insert(uri, values);  
  11.     }  
  12.       
  13.     public void testDelete() throws Throwable{  
  14.         ContentResolver resolver = getContext().getContentResolver();  
  15.         Uri uri = Uri.parse("content://cn.test.providers.personprovider/person");  
  16.         int num =resolver.delete(uri, null, null);  
  17.     }  
  18.       
  19.     public void testUpdate() throws Throwable{  
  20.         ContentResolver resolver = getContext().getContentResolver();  
  21.         Uri uri = Uri.parse("content://cn.test.providers.personprovider/person/65");  
  22.         ContentValues values = new ContentValues();  
  23.         values.put("amount", 500);  
  24.         resolver.update(uri, values, null, null);  
  25.     }  
  26.       
  27.     public void testQuery() throws Throwable{  
  28.         ContentResolver resolver = getContext().getContentResolver();  
  29.         Uri uri = Uri.parse("content://cn.test.providers.personprovider/person/65");  
  30.         Cursor cursor = resolver.query(uri, null, null, null, "personid asc");  
  31.         while(cursor.moveToNext()){  
  32.             String name = cursor.getString(cursor.getColumnIndex("name"));  
  33.             Log.i("AccessContentProviderTest", name);  
  34.         }  
  35.     }  
  36. }  

相关内容