自定义ContentProvider需要在项目清单中注册:

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;
import android.provider.UserDictionary.Words;

public class DictProvider extends ContentProvider{
  private static UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH);
  private static final int WORDS = 1;
  private static final int WORD = 2;
  private MyDatabaseHelper dbOpenHelper;
  static{
    //为UriMatcher注册两个Uri
    matcher.addURI(mediaprovidertest.Words.AUTHORITY, "words", WORDS);
    matcher.addURI(mediaprovidertest.Words.AUTHORITY, "word/#", WORD);
  }

  //第一次调用该DictProvider时,系统先创建DictProvider对象,并回调该方法
  @Override
  public boolean onCreate() {
    dbOpenHelper = new MyDatabaseHelper(this.getContext(),"myDict.db3",null,1);
    return true;
  }

  //查询数据的方法
  @Override
  public Cursor query(Uri uri, String[] projection, String selection,
    String[] selectionArgs, String sortOrder) {
    SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
    switch (matcher.match(uri)) {
      case WORDS:
        //执行查询
        return db.query("dict", projection,
            selection, selectionArgs, null, null, sortOrder);
      case WORD:
        //解析出想查询的记录ID
        long id = ContentUris.parseId(uri);
        String where =mediaprovidertest.Words.Word._ID+"="+id;
        //如果原来的where子句存在,拼接where子句
        if(selection != null && "".equals(selection)){
          where = where + " and "+selection;
        }
        return db.query("dict", projection, where, selectionArgs,
                null, null, sortOrder);

      default:
        throw new IllegalArgumentException("未知Uri:"+uri);
     }
  }

  //返回指定Uri参数对应的数据的MIME类型
  @Override
  public String getType(Uri uri) {
    switch (matcher.match(uri)) {
      //如果操作的数据是多项记录
      case WORDS:
        return "vnd.android.cursor.dir/org.crazyit.dict";
      //如果操作的数据时单项记录
      case WORD:
        return "vnd.android.cursor.item/org.crazyit.dict";
      default:
        throw new IllegalArgumentException("未知Uri:"+uri);
    }
  }

  //插入数据
  @Override
  public Uri insert(Uri uri, ContentValues values) {
    // 获得数据库实例
    SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
    //插入数据,返回行ID
    long rowId = db.insert("dict", mediaprovidertest.Words.Word._ID, values);
    //如果插入成功则返回uri
    if(rowId>0){
      //在已有的Uri的后面追加ID数据
      Uri wordUri = ContentUris.withAppendedId(uri, rowId);
      //通知数据已经改变
      getContext().getContentResolver().notifyChange(wordUri, null);
      return wordUri;
    }
    return null;
  }

  //删除数据的方法
  @Override
  public int delete(Uri uri, String selection, String[] selectionArgs) {
    SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
    //记录所删除的记录数
    int num = 0;
    //对Uri进行匹配
    switch (matcher.match(uri)) {
      case WORDS:
        num = db.delete("dict", selection, selectionArgs);
        break;
      case WORD:
        //解析出所需要删除的记录ID
        long id = ContentUris.parseId(uri);
        String where = mediaprovidertest.Words.Word._ID+"="+id;
        //如果原来的where子句存在,拼接where子句
        if(selection != null && selection.equals("")){
          where = where +" and "+selection;
        }
        num = db.delete("dict", where, selectionArgs);
        break;
    default:
      try {
        throw new IllegalAccessException("未知Uri:"+uri);
      } catch (IllegalAccessException e) {
        e.printStackTrace();
      }
    }
    //通知数据已经改变
    return num;
  }

  //修改数据的方法
  @Override
  public int update(Uri uri, ContentValues values, String selection,
        String[] selectionArgs) {
    SQLiteDatabase db = dbOpenHelper.getWriteDatabase();
    //记录所修改的记录数
    int num = 0;
    switch (matcher.match(uri)) {
      case WORDS:
        num = db.update("dict", values, selection, selectionArgs);
        break;
      case WORD:
        //解析出想修改的记录ID
        long id = ContentUris.parseId(uri);
        String where = mediaprovidertest.Words.Word._ID+"="+id;
        //如果原来的where子句存在,拼接where子句
        if(selection != null && selection.equals("")){
          where = where +" and "+selection;
        }
        num = db.update("dict", values, where, selectionArgs);
      default:
        throw new IllegalArgumentException("未知Uri:"+uri);
     }
    //通知数据已经改变
    getContext().getContentResolver().notifyChange(uri, null);
      return 0;
   }

}

使用ContentProContentProvider共享生词本数据的更多相关文章

  1. PHP 实现多网站共享用户SESSION 数据解决方案

    PHP 实现多网站共享用户SESSION 数据解决方案 来源URL:http://blog.csdn.net/dongdongzzcs/article/details/6906613 一.问题起源 稍 ...

  2. 【Excle数据透视表】如何创建非共享缓存的数据透视表

    一般情况下,利用同一个数据源创建多个数据表时,默认创建的是共享缓存的数据透视表.刷新一个数据透视表时会影响其他数据透视表的展示结果. 解决方案 创建非共享缓存的多个数据透视表 步骤一 单击工作表数据任 ...

  3. 5、docker容器数据卷: -v添加共享传递容器数据卷

    1.是什么 1.docker理念 先来看看Docker的理念:*  将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的*  容器之间希望有可能共享数据 2.保 ...

  4. 【CUDA 基础】5.2 共享内存的数据布局

    title: [CUDA 基础]5.2 共享内存的数据布局 categories: - CUDA - Freshman tags: - 行主序 - 列主序 toc: true date: 2018-0 ...

  5. session共享原理以及PHP 实现多网站共享用户SESSION 数据解决方案

    参考自: http://www.cnblogs.com/qulinke/articles/6003049.html https://segmentfault.com/q/101000000578847 ...

  6. 大数据freestyle: 共享单车轨迹数据助力城市合理规划自行车道

    编者按:近年来,异军突起的共享单车极大地解决了人们共同面临的“最后一公里”难题,然而,共享单车发展迅猛,自行车道建设却始终没有能够跟上脚步.幸运的是摩拜单车大量的轨迹数据为我们提供了一种新的思路:利用 ...

  7. 011.Kubernetes使用共享存储持久化数据

    本次实验是以前面的实验为基础,使用的是模拟使用kubernetes集群部署一个企业版的wordpress为实例进行研究学习,主要的过程如下: 1.mysql deployment部署, wordpre ...

  8. 在Owin Self-Hosing下实现每个请求中共享上下文(数据)

    问题 这几天在做公司的外部WebApi网关,由于使用了OAuth2.0,所以不得不使用Owin来部署网关. 而涉及到请求上下文的问题,为了使业务层能获取到请求头的信息,又不与网关耦合,决定把请求信息写 ...

  9. Unity 3D Framework Designing(5)——ViewModel之间如何共享数据

    对于客户端应用程序而言,单页应用程序(Single Page Application)是最常见的表现形式.有经验的开发人员往往会把一个View分解多个SubView.那么,如何在多个SubView之间 ...

随机推荐

  1. iOS - Swift NSKeyedArchiver 数据归档

    前言 public class NSKeyedArchiver : NSCoder public class NSKeyedUnarchiver : NSCoder 在 OC 语言中,归档是一个过程, ...

  2. SAP接口编程 之 JCo3.0系列(01):JCoDestination

    SAP接口编程 之 JCo3.0系列(01):JCoDestination 字数2101 阅读103 评论0 喜欢0 JCo3.0是Java语言与ABAP语言双向通讯的中间件.与之前1.0/2.0相比 ...

  3. hdu4570Multi-bit Trie

    链接 13年长沙邀请赛的题,神题意~ 题意:摘自http://blog.csdn.net/libin56842/article/details/9703457 这题题意确实有点难懂,起码对于我这个英语 ...

  4. Linux下查看文件权限、修改文件权限的方法

    查看权限命令查看目录的相关权限可以采用命令ls -lD,或者直接用ls -la 如 ls -l www.jb51.net  //这里表示查看www.jb51.net目录 修改权限命令 chmod 77 ...

  5. jquery_dialog实现效果

    jquery_dialog实现效果 jquery_dialog.js <!-- /******************************************************** ...

  6. Hadoop与Spark比较

    先看这篇文章:http://www.huochai.mobi/p/d/3967708/?share_tid=86bc0ba46c64&fmid=0 直接比较Hadoop和Spark有难度,因为 ...

  7. 如何部署Scrapy 到Scrapyd上?

    安装上传工具 1.上传工具 scrapyd-client 2.安装方法: pip install scrapyd-client 3.上传方法: python d:\Python27\Scripts\s ...

  8. 2010 word 如何新建目录

    首先插入一个bullet 填充内容,编好编号,选择文字,右键,然后选择相应的level,然后点击一级菜单reference, 然后点击table of contents, 选择某一个样式,然后插入成功 ...

  9. 销售 >> 当今社会生产力最大的源泉为 >>自助服务 与推销员随之消失

    销售可能是变化最大的企业职能.比如,经济学家喜欢提出陷阱问题“什么概念或者想法成为当今社会生产力最大的源泉?” 大多数人回答计算机,  正确的回答是自助服务与推销员随之消失               ...

  10. 如何用腾讯云打造一款微视频APP

    版权声明:本文由腾讯云原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/196 来源:腾云阁 https://www.qclo ...