歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Android使用內容提供者方式進行存儲

Android使用內容提供者方式進行存儲

日期:2017/3/1 11:17:32   编辑:Linux編程

內容提供者(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. @Override
  12. public boolean onCreate() {
  13. dbOpenHelper = new DBOpenHelper(getContext());
  14. return true;
  15. }
  16. @Override
  17. public Cursor query(Uri uri, String[] projection, String selection,
  18. String[] selectionArgs, String sortOrder) {
  19. SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
  20. switch (MATCHER.match(uri)) {
  21. case PERSONS: // 獲取person表中的所有數據 /person
  22. return db.query("person", projection, selection, selectionArgs, null, null, sortOrder);
  23. case PERSON: // 獲取person表中的指定id的數據 /person/20
  24. long id = ContentUris.parseId(uri);
  25. String where = "personid="+ id;
  26. if(selection!=null && !"".equals(selection.trim())){
  27. where += " and "+ selection;
  28. }
  29. return db.query("person", projection, where, selectionArgs, null, null, sortOrder);
  30. default:
  31. throw new IllegalArgumentException("Unknown Uri:"+ uri);
  32. }
  33. }
  34. @Override
  35. public String getType(Uri uri) {
  36. // TODO Auto-generated method stub
  37. return null;
  38. }
  39. @Override
  40. public Uri insert(Uri uri, ContentValues values) {
  41. //取得數據庫操作實例
  42. SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
  43. switch (MATCHER.match(uri)) {
  44. case PERSONS:
  45. //執行添加,返回行號,如果主健字段是自增長的,那麼行號會等於主鍵id
  46. long rowid = db.insert("person", "name", values);
  47. //得到拼好的uri
  48. Uri insertUri = ContentUris.withAppendedId(uri, rowid);
  49. //發出數據變化通知(person表的數據發生變化)
  50. getContext().getContentResolver().notifyChange(uri, null);
  51. return insertUri;
  52. default:
  53. //不能識別uri
  54. throw new IllegalArgumentException("Unknown Uri:"+ uri);
  55. }
  56. }
  57. @Override
  58. public int delete(Uri uri, String selection, String[] selectionArgs) {
  59. SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
  60. //受影響的行數
  61. int num = 0;
  62. switch (MATCHER.match(uri)) {
  63. case PERSONS: // 刪除person表中的所有數據 /person
  64. num = db.delete("person", selection, selectionArgs);
  65. break;
  66. case PERSON: // 刪除person表中的指定id的數據 /person/20
  67. long id = ContentUris.parseId(uri);
  68. String where = "personid="+ id;
  69. if(selection!=null && !"".equals(selection.trim())){
  70. where += " and "+ selection;
  71. }
  72. num = db.delete("person", where, selectionArgs);
  73. break;
  74. default:
  75. throw new IllegalArgumentException("Unknown Uri:"+ uri);
  76. }
  77. return num;
  78. }
  79. @Override
  80. public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
  81. SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
  82. int num = 0;
  83. switch (MATCHER.match(uri)) {
  84. case PERSONS: // 更新person表中的所有數據 /person
  85. num = db.update("person", values, selection, selectionArgs);
  86. break;
  87. case PERSON: // 更新person表中的指定id的數據 /person/20
  88. long id = ContentUris.parseId(uri);
  89. String where = "personid="+ id;
  90. if(selection!=null && !"".equals(selection.trim())){
  91. where += " and "+ selection;
  92. }
  93. num = db.update("person", values, where, selectionArgs);
  94. break;
  95. default:
  96. throw new IllegalArgumentException("Unknown Uri:"+ uri);
  97. }
  98. return num;
  99. }
  100. }

其他工程中訪問:

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