博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android之自定义contentprovider
阅读量:7157 次
发布时间:2019-06-29

本文共 8184 字,大约阅读时间需要 27 分钟。

1、ContentProviderTestActivity 类中有2个按钮,分别插入数据为查询数据

2、DataBaseConfiguation 为程序所用到的配置信息 注:TableConfiguation内部类实现BaseColumns,即声明了_ID 和 _COUNT

3、MyContentProvider 自定义ContentProvider,继承与ContentProvider

其中 uriMatcher 为Uri的匹配器,在静态块中初始化URI。 columnMap为表结构的映射mapping

在getType方法中要根据访问的Uri确定访问资源的类型,以字符串形式返回。

格式为:"vnd.android.cursor.dir/vnd.catking.userList"、"vnd.android.cursor.item/vnd.catking.userItem";

注释掉,对程序运行无影响。

注意:

static{

  //初始化URI

  uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
  uriMatcher.addURI(DataBaseConfiguation.AUTHORITY, "user", USER_LIST_CODE);
  uriMatcher.addURI(DataBaseConfiguation.AUTHORITY, "user/#", USER_RECORD_CODE);
   红色字体中,的格式为xxx/xx,并不是/xxx/xx,其中*号匹配所有字符,#匹配所有数字
  //表结构的映射
  columnMap.put(DataBaseConfiguation.TableConfiguation._ID, DataBaseConfiguation.TableConfiguation._ID);
  columnMap.put(DataBaseConfiguation.TableConfiguation.USER_NAME, DataBaseConfiguation.TableConfiguation.USER_NAME);
 }

 

最后在AndroidManifest.xml里配上

<provider android:authorities="com.catking.contentprovider.MyContentProvider" android:name="com.catking.contentprovider.MyContentProvider" />

authorities的值必须与DataBaseConfiguation.AUTHORITY一致 

 

ContentProviderTestActivity:

import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import com.catking.cfg.DataBaseConfiguation;
public 
class ContentProviderTestActivity 
extends Activity {
    
private Button insertBtn;
    
private Button queryBtn;
    @Override
    
public 
void onCreate(Bundle savedInstanceState) {
        
super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        insertBtn = (Button) findViewById(R.id.insert);
        queryBtn = (Button) findViewById(R.id.query);
        
        insertBtn.setOnClickListener(
new InsertOnClickListener());
        queryBtn.setOnClickListener(
new QueryOnClickListener());
    }
    
    
class InsertOnClickListener 
implements OnClickListener{
        @Override
        
public 
void onClick(View v) {
            ContentValues values = 
new ContentValues();
            values.put(DataBaseConfiguation.TableConfiguation.USER_NAME, "张三");
            Uri uri = getContentResolver().insert(DataBaseConfiguation.TableConfiguation.CONTENT_URI, values);
            System.out.println("uri------------------->" + uri);
        }
    }
    
    
class QueryOnClickListener 
implements OnClickListener{
        @Override
        
public 
void onClick(View v) {
            Cursor cursor = getContentResolver().query(DataBaseConfiguation.TableConfiguation.CONTENT_URI,
                    
null
null
null
null);
            
while (cursor.moveToNext()) {
                System.out.println(cursor.getString(cursor.getColumnIndex(DataBaseConfiguation.TableConfiguation.USER_NAME)));
            }
        }
        
    }
}

DataBaseConfiguation:

package com.catking.cfg;
import android.net.Uri;
import android.provider.BaseColumns;
public 
class DataBaseConfiguation {
    
public 
static 
final String AUTHORITY = "com.catking.contentprovider.MyContentProvider";
    
public 
static 
final String DATABASE_NAME = "cp_db";
    
public 
static 
final 
int DATABASE_VERSION = 1;
    
    
public 
static 
class TableConfiguation 
implements BaseColumns{
        
public 
static 
final String TABLE_NAME = "user";
        
public 
static 
final Uri CONTENT_URI = Uri.parse("content://" + DataBaseConfiguation.AUTHORITY + "/" + TABLE_NAME);
        
public 
static 
final String CONTENT_TYPE_DIR = "vnd.android.cursor.dir/vnd.catking.userList";
        
public 
static 
final String CONTENT_TYPE_RECORD = "vnd.android.cursor.item/vnd.catking.userItem";
        
public 
static 
final String USER_NAME = "name";
        
public 
static 
final String DEFAULT_SORT_ORDER = "_id desc";
    }

MyContentProvider:

public 
class MyContentProvider 
extends ContentProvider {
    
    
private 
static 
final UriMatcher uriMatcher;
    
private 
static 
final 
int USER_LIST_CODE = 1;
    
private 
static 
final 
int USER_RECORD_CODE = 2;
    
private SQLiteOpenHelper dbh;
    
private 
static Map<String, String> columnMap = 
new HashMap<String, String>();
    
    
static{
        uriMatcher = 
new UriMatcher(UriMatcher.NO_MATCH);
        uriMatcher.addURI(DataBaseConfiguation.AUTHORITY, "user", USER_LIST_CODE);
        uriMatcher.addURI(DataBaseConfiguation.AUTHORITY, "user/#", USER_RECORD_CODE);
        
        
        columnMap.put(DataBaseConfiguation.TableConfiguation._ID, DataBaseConfiguation.TableConfiguation._ID);
        columnMap.put(DataBaseConfiguation.TableConfiguation.USER_NAME, DataBaseConfiguation.TableConfiguation.USER_NAME);
    }
    
    @Override
    
public 
boolean onCreate() {
        dbh = 
new MySQLiteOpenHelper(getContext(), DataBaseConfiguation.DATABASE_NAME, 
null, DataBaseConfiguation.DATABASE_VERSION);
        System.out.println("dbh ������");
        
return 
true;
    }
    @Override
    
public String getType(Uri uri) {
        System.out.println("getTypeִ��");
        
switch (uriMatcher.match(uri)) {
        
case USER_LIST_CODE:
            
return DataBaseConfiguation.TableConfiguation.CONTENT_TYPE_DIR;
        
case USER_RECORD_CODE:
            
return DataBaseConfiguation.TableConfiguation.CONTENT_TYPE_RECORD;
        
default:
            
throw 
new RuntimeException("unknown uri " + uri.toString());
        }
    }
    @Override
    
public Uri insert(Uri uri, ContentValues values) {
        System.out.println("insert ִ��");
        SQLiteDatabase db = dbh.getWritableDatabase();
        
long rowId = db.insert(DataBaseConfiguation.TableConfiguation.TABLE_NAME, 
null, values);
        
if (rowId > 0) {
            Uri insertedUri = ContentUris.withAppendedId(DataBaseConfiguation.TableConfiguation.CONTENT_URI, rowId);
            getContext().getContentResolver().notifyChange(insertedUri, 
null);
            
return insertedUri;
        }
        
throw 
new SQLException("fail to insert row into " + uri.toString());
    }
    @Override
    
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
        System.out.println(DataBaseConfiguation.TableConfiguation.CONTENT_URI);
        SQLiteDatabase db = dbh.getReadableDatabase();
        SQLiteQueryBuilder qb = 
new SQLiteQueryBuilder();
        qb.setTables(DataBaseConfiguation.TableConfiguation.TABLE_NAME);
        qb.setProjectionMap(columnMap);
        
switch (uriMatcher.match(uri)) {
        
case USER_LIST_CODE:
            
break;
        
case USER_RECORD_CODE:
            System.out.println("��ʼ��ѯuri.getPathSegments()����");
            
for (String s : uri.getPathSegments()) {
                System.out.println(s);
            }
            System.out.println("�����ѯuri.getPathSegments()����");
            qb.appendWhere(DataBaseConfiguation.TableConfiguation.USER_NAME + "=" + uri.getPathSegments().get(1));
            
break;
        
default:
            
throw 
new RuntimeException("unknown uri " + uri.toString());
        }
        Cursor c = db.query(DataBaseConfiguation.TableConfiguation.TABLE_NAME, projection, selection, selectionArgs, 
null
null,
                DataBaseConfiguation.TableConfiguation.DEFAULT_SORT_ORDER);
        c.setNotificationUri(getContext().getContentResolver(), uri);
        
return c;
    }
    @Override
    
public 
int delete(Uri uri, String selection, String[] selectionArgs) {
        
//
 TODO Auto-generated method stub
        
return 0;
    }
    @Override
    
public 
int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
        
//
 TODO Auto-generated method stub
        
return 0;
    }
}  

 

MySQLiteOpenHelper:

public 
class MySQLiteOpenHelper 
extends SQLiteOpenHelper {
    
public MySQLiteOpenHelper(Context context, String name, CursorFactory factory, 
int version) {
        
super(context, name, factory, version);
    }
    @Override
    
public 
void onCreate(SQLiteDatabase db) {
        System.out.println("createDB excuted");
        String createSQL = "create table " + DataBaseConfiguation.TableConfiguation.TABLE_NAME + "("
                + DataBaseConfiguation.TableConfiguation._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, "
                + DataBaseConfiguation.TableConfiguation.USER_NAME + " VARCHAR(20)" + ")";
        System.out.println(createSQL);
        db.execSQL(createSQL);
    }
    @Override
    
public 
void onUpgrade(SQLiteDatabase db, 
int oldVersion, 
int newVersion) {
        System.out.println("onUpgrade excuted");
    }
}  

AndroidManifest:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    
package="com.catking.activity"
    android:versionCode="1"
    android:versionName="1.0" >
    <uses-sdk android:minSdkVersion="8" />
    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".ContentProviderTestActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        
        <provider android:authorities="com.catking.contentprovider.MyContentProvider" android:name="com.catking.contentprovider.MyContentProvider" />
    </application>
</manifest>  

参考自: 

转载地址:http://lohgl.baihongyu.com/

你可能感兴趣的文章
win7升级nodejs8
查看>>
http断点续传
查看>>
悬浮显示input中所有的内容及css处理文字过长时显示为多余部分省略
查看>>
无线覆盖项目初步地勘——高校案例
查看>>
Hadoop MapReduce 处理2表join编程案例
查看>>
分布式存储-FastDFS
查看>>
iOS界面布局之三——纯代码的autoLayout及布局动画
查看>>
zabbix_server 3.0 安装
查看>>
Linux常用命令——find
查看>>
数据中台专栏(三):数据质量分析及提升
查看>>
iOS多点触控与手势识别
查看>>
Sql server--索引
查看>>
UML建模工具
查看>>
视频合成软件哪个好,怎么把多个视频快速合并成一个视频
查看>>
在Linux系统中创建SSH服务器别名
查看>>
【JMS 4】spring 整合activemq
查看>>
PDF文档页码怎么设置
查看>>
java单例模式
查看>>
多线程基础 (八)NSOperation相关
查看>>
【已解决】PHP项目需求:在现有网站中每个页面增加一个get参数
查看>>