在之前提供了小例子BookProvider,我们回过头看看如何将通过该Content Provider进行数据的读取。

(1)增加

private void addBook(String name ,String isbn,String author){ 
   /* 从ContentProvider的insert()方法的参数可以看到,通过ContentValues来进行数据的传递。ContentValues是key/values对,可以存储多个组,非常适合传递信息 */ 
   ContentValues cv = new ContentValues(); 
    cv.put(BookTableMetaData.BOOK_NAME, name); 
    cv.put(BookTableMetaData.BOOK_ISBN, isbn); 
    cv.put(BookTableMetaData.BOOK_AUTHOR, author); 
    /* ContentResolver负责将URI reference解析到正确的provider上,并对该provider的公开的读写接口进行操作。它的方法和provider提供的方法一一对应,并增加了uri参数。*/ 
   ContentResolver cr = getContentResolver(); 
    Uri insertUri = cr.insert(BookProviderMetaData.BookTableMetaData.CONTENT_URI, cv); //对应BookProvider的insert() 
}

(2)删除

private void delBook(String name){ 
   ContentResolver cr = getContentResolver(); 
    int count = cr.delete(BookProviderMetaData.BookTableMetaData.CONTENT_URI,    /* Uri          uri */ 
                     BookTableMetaData.BOOK_NAME + "=?",                    /* String         WhereClause */ 
                     new String[]{name});                                                        /* String[]        selectionArgs */ 
}

(3)修改: update和insert非常相似,也是通过ContentValues传递修改内容。

private void updateBookIsbn(String name ,String newIsbn,String newAuthor){ 
    ContentValues cv = new ContentValues(); 
    cv.put(BookTableMetaData.BOOK_NAME, name); 
    cv.put(BookTableMetaData.BOOK_ISBN, newIsbn); 
    cv.put(BookTableMetaData.BOOK_AUTHOR, newAuthor); 
    
    ContentResolver cr = getContentResolver(); 
    int count = cr.update(BookProviderMetaData.BookTableMetaData.CONTENT_URI,
     /* Uri        uri */ 
                      cv,                                                                               /* ContentValues  values */ 
                      BookTableMetaData.BOOK_NAME + "=?",            /* String           WhereClause */ 
                      new String[]{name});                                                /* String[]         selectionArgs */ 
}

(4)查询

private void showBooks(){ 
    Uri uri = BookProviderMetaData.BookTableMetaData.CONTENT_URI; 
     /*方式一,通过managedQuery( )*/ 
    @SuppressWarnings("deprecation") 
    Cursor c = managedQuery(uri, null, null, null, null); 
    /* 方式二:利用ContentResolver的query来获取*/ 
    // ContentResolver cr = getContentResolver(); 
    // Cursor c = cr.query(uri, null, null, null, null); 
    int iIndex = c.getColumnIndex(BookTableMetaData._ID); 
    int iName = c.getColumnIndex(BookTableMetaData.BOOK_NAME); 
    int iIsbn = c.getColumnIndex(BookTableMetaData.BOOK_ISBN); 
    int iAuthor = c.getColumnIndex(BookTableMetaData.BOOK_AUTHOR);

/* 需要注意,通过下面showInfo显示,各列的Id并非按我们的创建table的列的顺序,所以一定要先获取列的ID。至于row的_id,是按顺序提供,为当前最大的_id+1。但除非我们能很明确清楚,一般不使用这些系统内部安排的Id */ 
    showInfo("ColumnIndex _id=" + iIndex + ",name=" + iName + ",isdn=" + iIsbn + ", author=" + iAuthor); 
    showInfo("Totle books : " + c.getCount()); 
    for(c.moveToFirst(); !c.isAfterLast();c.moveToNext()){ 
        String id = c.getString(iIndex); 
        String name = c.getString(iName); 
        String isbn = c.getString(iIsbn); 
        String author = c.getString(iAuthor); 
        showInfo("[" +id + "]" + "\t" + name + "\t" + isbn  + "\t" + author); 
    } 
    c.close(); 
}

相关链接: 我的Android开发相关文章

转自http://blog.csdn.net/flowingflying/article/details/9243275

【转】Pro Android学习笔记(八):了解Content Provider(下中)的更多相关文章

  1. 【转】 Pro Android学习笔记(八二):了解Package(1):包和进程

    文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog.csdn.net/flowingflying/ 在之前,我们已经学习了如何签发apk,见P ...

  2. 【转】 Pro Android学习笔记(八六):了解Package(5):使用lib

    目录(?)[-] 在项目中使用lib 源代码 了解一些机制 文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog.csdn.net/flowin ...

  3. 【转】 Pro Android学习笔记(八四):了解Package(3):包间数据共享

    目录(?)[-] 共享User ID的设置 共享资源例子 文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog.csdn.net/flowing ...

  4. 【转】 Pro Android学习笔记(八五):了解Package(4):lib项目

    目录(?)[-] 什么是lib项目 小例子 Lib的实现 文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog.csdn.net/flowing ...

  5. 【转】 Pro Android学习笔记(十九):用户界面和控制(7):ListView

    目录(?)[-] 点击List的item触发 添加其他控件以及获取item数据 ListView控件以垂直布局方式显示子view.系统的android.app.ListActivity已经实现了一个只 ...

  6. Pro Android学习笔记 ActionBar(1):Home图标区

     Pro Android学习笔记(四八):ActionBar(1):Home图标区 2013年03月10日 ⁄ 综合 ⁄ 共 3256字 ⁄ 字号 小 中 大 ⁄ 评论关闭 ActionBar在A ...

  7. 【转】 Pro Android学习笔记(五五):调试和分析(3):adb命令、模拟器控制台和StrictMode

    目录(?)[-] adb命令 模拟器Console StrictMode adb命令 我们在学习SQLite的使用,介绍过部分adb命令的使用,见Pro Android学习笔记(五):了解Conten ...

  8. 【转】 Pro Android学习笔记(五六):配置变化

    目录(?)[-] Activity的destorycreate过程 Fragment的destorycreate过程 onSaveInstanceState saveFragmentInstanceS ...

  9. 【转】 Pro Android学习笔记(四十):Fragment(5):适应不同屏幕或排版

    目录(?)[-] 设置横排和竖排的不同排版风格 改写代码 对于fragment,经常涉及不同屏幕尺寸和不同的排版风格.我们在基础小例子上做一下改动,在横排的时候,仍是现实左右两个fragment,在竖 ...

  10. 【转】 Pro Android学习笔记(二二):用户界面和控制(10):自定义Adapter

    目录(?)[-] 设计Adapter的布局 代码部分 Activity的代码 MyAdapter的代码数据源和构造函数 MyAdapter的代码实现自定义的adapter MyAdapter的代码继续 ...

随机推荐

  1. recognition rate generalization识别率 泛化

    http://www1.inf.tu-dresden.de/~ds24/lehre/ml_ws_2013/ml_11_hinge.pdf Two extremes: • Big

  2. hibernate Session的CRUD操作

    使用Session里面的方法进行CRUD操作 (1) 增加 save 方法 (2) 查找 get 方法(根据id查) (3) 修改 update 方法 (4) 删除 delete 方法 1.增加 /* ...

  3. cocos2d-x 源代码分析 : control 源代码分析 ( 控制类组件 controlButton)

    源代码版本号来自3.1rc 转载请注明 cocos2d-x源代码分析总文件夹 http://blog.csdn.net/u011225840/article/details/31743129 1.继承 ...

  4. CentOS 7.0 systemd

    CentOS 7 已经切换到 systemd,系统指令也有所变化.之前用于启动.重启.停止各种服务的service 作为向后兼容的指令还能使用,但是将来可能会消失.同时,chkconfig 也改成了s ...

  5. htop的使用

    htop是top的增强版本.官网地址: http://hisham.hm/htop/ 这网站比较...... 实验环境: [root@miyan ~]# cat /etc/redhat-release ...

  6. 改善程序与设计的55个具体做法 day2

    条款05:了解C++默默编写并调用哪些函数 如果没有为类定义构造函数.析构函数.拷贝构造函数.重载赋值操作符,并且这些函数被需要(调用)时,编译器会为类生成默认的函数,而这些函数是public inl ...

  7. virtualbox 桥接 (转)

    virtualbox 自带的网络配置模式要么选择host-only,要么bridge,对于经常使用virtualbox的同学一定想要像vmware一样的nat配置,既可以让host访问guest,又可 ...

  8. maven导入项目时,缺少部分source folder

    今天导入公司的maven项目时,少了一些source folder,运行启动正常,但是页面打不开,找不到对应的目录文件,使用maven更新项目,重启编辑器也无效. 问题描述如图所示,缺少了图中的2个目 ...

  9. 图形用户界面(GUI)事件监听机制——窗体事件Frame

    窗体事件.Button的使用 本事例给出一个窗体的定义方法,基本属性设置,给窗体添加退出按钮,让按钮具备退出的功能.熟悉监听器的使用 按钮就是事件源. 那么选择哪一个监听器呢? 通过关闭窗体事例了解到 ...

  10. [原创]Scala学习:函数的定义

    方式一:标准的定义函数 def 函数名(参数1: 参数类型,参数2: 参数类型): 返回值类型 = { 函数体 } 例子 def max(x: Int,y: Int): Int ={ if(x > ...