服务端(ContentProvider)

  • 目录结构图:

  • MainActivity.java:

    package com.qf.day17_contentprovider_words_demo2;
    
    import android.app.Activity;
    import android.database.Cursor;
    import android.os.Bundle;
    import android.view.View;
    import android.widget.EditText;
    import android.widget.ListView;
    import android.widget.SimpleCursorAdapter; import com.qf.day17_contentprovider_words_demo2.db.MyOpenHelper; public class MainActivity extends Activity { private EditText etWord,etChina;
    private ListView lv; private MyOpenHelper helper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main); etWord = (EditText) findViewById(R.id.et_word);
    etChina = (EditText) findViewById(R.id.et_china);
    lv = (ListView) findViewById(R.id.lv); helper = new MyOpenHelper(MainActivity.this); getData();
    } //点击事件 提交按钮
    public void MyClick(View v){ String strWord = etWord.getText().toString().trim();
    String strChina= etChina.getText().toString().trim();
    String sql = "insert into tb_words(word,detail)values(?,?)";
    helper.execData(sql, new String[]{strWord,strChina}); getData(); } public void getData(){ String sql = "select * from tb_words";
    Cursor cursor = helper.queryData(sql, null); SimpleCursorAdapter adapter = new SimpleCursorAdapter(MainActivity.this,
    R.layout.item, cursor,
    new String[]{"word","detail"},
    new int[]{R.id.tv_word,R.id.tv_china}, SimpleCursorAdapter.FLAG_REGISTER_CONTENT_OBSERVER); lv.setAdapter(adapter);
    } }
  • MyOpenHelper.java(数据库类):

    package com.qf.day17_contentprovider_words_demo2.db;
    
    import android.content.Context;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteDatabase.CursorFactory;
    import android.database.sqlite.SQLiteOpenHelper; public class MyOpenHelper extends SQLiteOpenHelper { private static final String NAME = "db_words.db";
    private static final int VERSION = 1; private SQLiteDatabase db; public MyOpenHelper(Context context, String name, CursorFactory factory,
    int version) {
    super(context, name, factory, version);
    // TODO Auto-generated constructor stub
    }
    public MyOpenHelper(Context context) {
    super(context, NAME, null, VERSION);
    // TODO Auto-generated constructor stub
    db = getReadableDatabase();
    } /**
    * 查询
    * @param sql
    * @param selectionArgs
    * @return
    */
    public Cursor queryData(String sql, String[] selectionArgs){ Cursor cursor = db.rawQuery(sql, selectionArgs);
    return cursor; } /**
    * 增加 修改 删除
    * @param sql
    * @param bindArgs
    */
    public boolean execData(String sql,Object[] bindArgs){
    try {
    if(bindArgs ==null){
    db.execSQL(sql);
    }else{
    db.execSQL(sql, bindArgs);
    } return true; } catch (Exception e) {
    // TODO: handle exception
    }
    return false;
    } @Override
    public void onCreate(SQLiteDatabase db) {
    // TODO Auto-generated method stub
    String sql ="create table if not exists tb_words(_id integer primary key autoincrement,word,detail)";
    //此表无作用只作为一个示范
    String sql1 ="create table if not exists tb_newwords(_id integer primary key autoincrement,word,detail)";
    db.execSQL(sql);
    db.execSQL(sql1); } @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // TODO Auto-generated method stub } }
  • MyContentProvider

    package com.qf.day17_contentprovider_words_demo2;
    
    import com.qf.day17_contentprovider_words_demo2.db.MyOpenHelper;
    
    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; public class MyContentProvider extends ContentProvider{ private MyOpenHelper helper;
    private SQLiteDatabase db; //com.qf.contentprovider_words.mycontentprovider 用于匹配意图的uri
    private static UriMatcher uriMatcher = new UriMatcher(UriMatcher.NO_MATCH); static{ /**第一个参数 :意图 和清单文件中的authorities 相同
    * 第二个参数 :路径
    * 第三个参数:对应uri对应编码
    * 通配符 : * 任意文本 #数字
    *
    * 例子uriMatcher.addURI("aa.bb","cc/#",1)
    * 例子uriMatcher.addURI("aa.bb","cc/*",2)
    *
    * 如果 在ContentResolver 的意图uri为 aa.bb.cc/3 那么跳转uriMatcher.addURI("aa.bb","cc/#",1)
    *
    */
    //在内容解析器中只需要 填写 uri即可 例子 : com.qf.contentprovider_words.mycontentprovider/words/123
    //content://com.qf.contentprovider_words.mycontentprovider/words/h
    uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider", "words", 1);
    uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider", "newwords", 2);
    uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider", "words/*", 3);//*匹配任意文本
    uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider", "words_id/#", 4);//*匹配任意数字
    uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider", "words_zh/*", 5);//*匹配任意中文 } @Override
    public boolean onCreate() {
    // TODO Auto-generated method stub
    helper = new MyOpenHelper(getContext());
    db = helper.getReadableDatabase();
    return false;
    } @Override
    public String getType(Uri uri) {
    // TODO Auto-generated method stub
    return null;
    } @Override
    public Cursor query(Uri uri, String[] projection, String selection,
    String[] selectionArgs, String sortOrder) {
    // TODO Auto-generated method stub Cursor cursor =null; switch (uriMatcher.match(uri)) {
    case 1:
    //tb_words表中所有数据
    cursor = db.query("tb_words", projection, selection, selectionArgs, null, null, sortOrder); break;
    case 2:
    //tb_newwords表中所有数据
    cursor = db.query("tb_newwords", projection, selection, selectionArgs, null, null, sortOrder); break;
    case 3:
    //tb_words表中符合条件 word
    String data = uri.getLastPathSegment();//获取Uri最后的参数
    cursor = db.query("tb_words", projection, "word like ?", new String[]{data+"%"}, null, null, sortOrder); break;
    case 4:
    //tb_words表中符合条件 _id
    String data1 = uri.getLastPathSegment();//获取Uri最后的参数
    cursor = db.query("tb_words", projection, "_id = ?", new String[]{data1+""}, null, null, sortOrder); break;
    case 5: //tb_words表中符合条件 detail
    String data2 = uri.getLastPathSegment();//获取Uri最后的参数
    cursor = db.query("tb_words", projection, "detail like ?", new String[]{data2+"%"}, null, null, sortOrder); break; default:
    break;
    } return cursor;
    } @Override
    public Uri insert(Uri uri, ContentValues values) {
    // TODO Auto-generated method stub Uri resultUri = null;
    switch (uriMatcher.match(uri)) {
    case 1: long l = db.insert("tb_words", null, values);
    /**
    * 两种皆可返回正确id
    */
    // resultUri = Uri.parse("content://com.qf.contentprovider_words.mycontentprovider/words/"+l);
    resultUri = ContentUris.withAppendedId(uri, l);
    break;
    case 2:
    long l1 = db.insert("tb_newwords", null, values);
    /**
    * 两种皆可返回正确id
    */
    // resultUri = Uri.parse("content://com.qf.contentprovider_words.mycontentprovider/newwords/"+l1);
    resultUri = ContentUris.withAppendedId(uri, l1);
    break; default:
    break;
    }
    return resultUri;
    } @Override
    public int update(Uri uri, ContentValues values, String selection,
    String[] selectionArgs) {
    // TODO Auto-generated method stub
    int num =0;
    switch (uriMatcher.match(uri)) {
    case 1:
    num = db.update("tb_words", values, selection, selectionArgs);
    break;
    case 2:
    num = db.update("tb_newwords", values, selection, selectionArgs);
    break; default:
    break;
    }
    return num;
    } @Override
    public int delete(Uri uri, String selection, String[] selectionArgs) {
    // TODO Auto-generated method stub
    int num =0;
    switch (uriMatcher.match(uri)) {
    case 1:
    num = db.delete("tb_words", selection, selectionArgs);
    break;
    case 2:
    num = db.delete("tb_newwords", selection, selectionArgs);
    break; default:
    break;
    }
    return num;
    } }
  • layout布局文件:

    item

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" > <TextView
    android:id="@+id/tv_word"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textColor="#f00"
    android:textSize="20sp"
    android:text="hello"
    />
    <TextView
    android:id="@+id/tv_china"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textColor="#00f"
    android:textSize="16sp"
    android:text="word"
    /> </LinearLayout>

    activity_main.xml

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" > <EditText
    android:id="@+id/et_word"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="请输入英文单词" />
    <EditText
    android:id="@+id/et_china"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="请输入对应的意思" /> <Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_margin="10dp"
    android:text="提交"
    android:onClick="MyClick"
    /> <TextView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="#999900"
    android:text="以下显示单词列表"
    /> <ListView
    android:id="@+id/lv"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:divider="#f00"
    android:dividerHeight="1dp"
    ></ListView> </LinearLayout>

客户端

  • 结构目录:

  • MainActivity.java:

    package com.qf.day17_contentprovider_wordc_demo2;
    
    import java.util.regex.Pattern;
    
    import android.app.Activity;
    import android.content.ContentResolver;
    import android.content.ContentUris;
    import android.content.ContentValues;
    import android.database.Cursor;
    import android.net.Uri;
    import android.os.Bundle;
    import android.text.TextUtils;
    import android.view.View;
    import android.widget.EditText;
    import android.widget.ListView;
    import android.widget.SimpleCursorAdapter; public class MainActivity extends Activity { // //content://com.qf.contentprovider_words.mycontentprovider/words/
    // uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider",
    // "words", 1);
    // uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider",
    // "newwords", 2);
    // uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider",
    // "words/*", 3);//*匹配任意文本
    // uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider",
    // "words_id/#", 4);//*匹配任意数字
    // uriMatcher.addURI("com.qf.contentprovider_words.mycontentprovider",
    // "words_zh/*", 5);//*匹配任意中文
    // private EditText etSearch;
    private ListView lv; @Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    etSearch = (EditText) findViewById(R.id.et_search);
    lv = (ListView) findViewById(R.id.lv);
    } public void MyClick(View v) {
    // 根据输入文本进行查询
    String strdata = etSearch.getText().toString().trim(); getData(strdata); } // 查询方法
    public void getData(String strdata) { ContentResolver resolver = getContentResolver();
    Uri uriWords = Uri.parse("content://com.qf.contentprovider_words.mycontentprovider/words");
    Uri uriWordsId = Uri.parse("content://com.qf.contentprovider_words.mycontentprovider/words_id");
    Uri uriWordsZh = Uri.parse("content://com.qf.contentprovider_words.mycontentprovider/words_zh");
    Cursor cursor = null;
    if (TextUtils.isEmpty(strdata)) {// 什么也没输入 直接查询所有
    cursor = resolver.query(uriWords, null, null, null, null);
    } else {
    if (isNumber(strdata)) {// 输入的数据 是否是数值
    // content://com.qf.contentprovider_words.mycontentprovider/words_id/45
    // 拼接id 123
    uriWordsId = ContentUris.withAppendedId(uriWordsId, Long.parseLong(strdata));
    cursor = resolver.query(uriWordsId, null, null, null, null);
    } else {
    if (isChina(strdata)) {// 是否是汉字
    // 拼接中文 张
    uriWordsZh = Uri.withAppendedPath(uriWordsZh, strdata);
    cursor = resolver.query(uriWordsZh, null, null, null, null);
    } else {
    // 拼接英文字符串
    uriWords = Uri.withAppendedPath(uriWords, strdata);
    cursor = resolver.query(uriWords, null, null, null, null);
    } }
    } SimpleCursorAdapter adapter = new SimpleCursorAdapter(MainActivity.this, R.layout.item, cursor,
    new String[] { "word", "detail" }, new int[] { R.id.tv_word, R.id.tv_china },
    SimpleCursorAdapter.FLAG_REGISTER_CONTENT_OBSERVER); lv.setAdapter(adapter); } // 判断是否是数字
    public boolean isNumber(String data) {
    Pattern pattern = Pattern.compile("[0-9]+");
    return pattern.matcher(data).matches(); } // 判断是否是中文
    public boolean isChina(String data) {
    Pattern pattern = Pattern.compile("[\u4e00-\u9fa5]+");
    return pattern.matcher(data).matches(); } }
  • layout布局:

    activity_main.xml:

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" > <EditText
    android:id="@+id/et_search"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="请输入查询内容" /> <Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="提交"
    android:onClick="MyClick"
    /> <TextView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="以下展示查询内容"
    android:background="#999900"
    />
    <ListView
    android:id="@+id/lv"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    ></ListView> </LinearLayout>

    item.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" > <TextView
    android:id="@+id/tv_word"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textColor="#f00"
    android:textSize="20sp"
    android:text="hello"
    />
    <TextView
    android:id="@+id/tv_china"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textColor="#00f"
    android:textSize="16sp"
    android:text="word"
    /> </LinearLayout>

17 一个ContentProvider的例子的更多相关文章

  1. Spring-Context之一:一个简单的例子

    很久之前就想系统的学习和掌握Spring框架,但是拖了很久都没有行动.现在趁着在外出差杂事不多,就花时间来由浅入深的研究下Spring框架.Spring框架这几年来已经发展成为一个巨无霸产品.从最初的 ...

  2. 高仿“点触验证码”做的一个静态Html例子

    先上源码: <html> <head> <title>TouClick - Designed By MrChu</title> <meta htt ...

  3. 一个UWSGI的例子

    摘要:uwsgi执行顺序:启动master进程,执行python脚本的公共代码(import同一层).然后生成worker进程,uwsgi.post_fork_hook=init_functions, ...

  4. Android 属性动画监听事件与一个菜单的例子

    简单监听事件 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 3 ...

  5. 《Java从入门到失业》第四章:类和对象(4.3):一个完整的例子带你深入类和对象

    4.3一个完整的例子带你深入类和对象 到此为止,我们基本掌握了类和对象的基础知识,并且还学会了String类的基本使用,下面我想用一个实际的小例子,逐步来讨论类和对象的一些其他知识点. 4.3.1需求 ...

  6. 用一个简单的例子来理解python高阶函数

    ============================ 用一个简单的例子来理解python高阶函数 ============================ 最近在用mailx发送邮件, 写法大致如 ...

  7. 关于apriori算法的一个简单的例子

    apriori算法是关联规则挖掘中很基础也很经典的一个算法,我认为很多教程出现大堆的公式不是很适合一个初学者理解.因此,本文列举一个简单的例子来演示下apriori算法的整个步骤. 下面这个表格是代表 ...

  8. 扩展Python模块系列(二)----一个简单的例子

    本节使用一个简单的例子引出Python C/C++ API的详细使用方法.针对的是CPython的解释器. 目标:创建一个Python内建模块test,提供一个功能函数distance, 计算空间中两 ...

  9. fitnesse - 一个简单的例子(slim)

    fitnesse - 一个简单的例子(slim) 2017-09-30 目录1 编写测试代码(Fixture code)2 编写wiki page并运行  2.1 新建wikiPage  2.2 运行 ...

随机推荐

  1. 2015 多校联赛 ——HDU5316(线段树)

    Fantasy magicians usually gain their ability through one of three usual methods: possessing it as an ...

  2. hdu 5135(2014广州—状态dp)

    t题意:给你n条边,构造任意个三角形,一个三角形恰好只用3条边,每条边只能一次,求面积最大值 思路: 最开始想的是先排序从大到小取,但感觉并不怎么靠谱. 最多12条边,所以可以求出所有可能的三角形面积 ...

  3. bzoj2007 NOI2010 网络流转对偶图

    2007: [Noi2010]海拔 Time Limit: 20 Sec  Memory Limit: 552 MBSubmit: 2775  Solved: 1331[Submit][Status] ...

  4. Android 自定义支持快速搜索筛选的选择控件(一)

    Android 自定义支持快速搜索筛选的选择控件 项目中遇到选择控件选项过多,需要快速查找匹配的情况. 做了简单的Demo,效果图如下: 源码地址:https://github.com/whieenz ...

  5. [ Java学习基础 ] Java的继承与多态

    看到自己写的东西(4.22的随笔[ Java学习基础 ] Java构造函数)第一次达到阅读100+的成就还是挺欣慰的,感谢大家的支持!希望以后能继续和大家共同学习,共同努力,一起进步!共勉! ---- ...

  6. c语言的第四次作业

    (一)改错题 输出三角形的面积和周长,输入三角形的三条边a.b.c,如果能构成一个三角形,输出面积area和周长perimeter(保留2位小数):否则,输出"These sides do ...

  7. Lua和C#调用探秘

    转载请标明出处:http://www.cnblogs.com/zblade/ 在实际的项目中,大部分业务逻辑 程序员只需要负责lua层编写逻辑即可,或者在c#层添加一些静态函数,供lua层调用.那么对 ...

  8. jqGrid 使用心得

    参考: https://blog.csdn.net/u012411219/article/details/51315419 https://www.cnblogs.com/kissdodog/p/38 ...

  9. Python小代码_5_二维矩阵转置

    使用列表推导式实现二维矩阵转置 matrix = [[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12]] print(matrix) matrix_t = [[ro ...

  10. 设计模式:HelloWorld之策略模式

    一.概述 策略模式 定义了算法族,分别封装起来,让他们可以互相替换,此模式让算法的变化独立于使用算法的客户. 策略模式的三要素: 抽象策略角色: 策略类,通常由一个接口或者抽象类实现. 具体策略角色: ...