效果图:

PetDbHelper

package com.example.admin.pets;

import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;import com.example.admin.pets.PetContract.PetEntry;

public class PetDbHelper extends SQLiteOpenHelper {

    private static  final  String DATABASE_NAME="shelter.db";    private static  final  int DATABASE_VERSION=1;

    public PetDbHelper(Context context){        super(context, DATABASE_NAME, null, DATABASE_VERSION);    }

    @Override    public void onCreate(SQLiteDatabase db) {        String SQL_CREATE_PETS_TABLE="CREATE TABLE "+PetEntry.TABLE_NAME+"("+ PetEntry._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, "                + PetEntry.COLUMN__PET_NAME + " TEXT NOT NULL, "                + PetEntry.COLUMN__PET_BREED + " TEXT, "                + PetEntry.COLUMN__PET_GENDER + " INTEGER NOT NULL, "                + PetEntry.COLUMN__PET_WEIGHT + " INTEGER NOT NULL DEFAULT 0);";        db.execSQL(SQL_CREATE_PETS_TABLE);

}

    @Override    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }}

PetProvider
package com.example.admin.pets;

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.util.Log;import com.example.admin.pets.PetContract.PetEntry;

public class PetProvider extends ContentProvider {

    public static final String LOG_TAG = PetProvider.class.getSimpleName();    private PetDbHelper petDbHelper;    private static final UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH);    private static final int PETS = 100;    private static final int PETS_ID = 101;

    static {        matcher.addURI(PetContract.CONTENT_AUTHORITY, PetContract.PATH_PETS, PETS);        matcher.addURI(PetContract.CONTENT_AUTHORITY, PetContract.PATH_PETS + "/#", PETS_ID); }

    @Override    public boolean onCreate() {        petDbHelper=new PetDbHelper(getContext());        return true;    }

    @Override    public Cursor query( Uri uri,  String[] projection, String selection,  String[] selectionArgs,String sortOrder) {        SQLiteDatabase sqLiteDatabase=petDbHelper.getReadableDatabase();        Cursor cursor;       final int match=matcher.match(uri);        switch (match){            case PETS:                cursor = sqLiteDatabase.query(PetContract.PetEntry.TABLE_NAME, projection, selection, selectionArgs, null, null,                        sortOrder);                break;            case PETS_ID:                selection = PetContract.PetEntry._ID + "=?";                selectionArgs = new String[]{String.valueOf(ContentUris.parseId(uri))};                cursor = sqLiteDatabase.query(PetContract.PetEntry.TABLE_NAME, projection, selection, selectionArgs, null, null,                        sortOrder);                break;            default:                throw new IllegalArgumentException("Cannot query unknown URL" + uri);

        }        cursor.setNotificationUri(getContext().getContentResolver(),uri);        return cursor;    }

    @Override    public Uri insert( Uri uri,  ContentValues values) {        final int match = matcher.match(uri);        switch (match) {            case PETS:                return insertPet(uri, values);            default:                throw new IllegalArgumentException("Insertion is not supported for " + uri);        }    }

    private Uri insertPet(Uri uri, ContentValues values) {        String name = values.getAsString(PetEntry.COLUMN__PET_NAME);

        if (name == null) {            throw new IllegalArgumentException("Pet requires a name"); }

        Integer gender = values.getAsInteger(PetEntry.COLUMN__PET_GENDER);        if (gender == null || !PetEntry.isValidGender(gender)) {            throw new IllegalArgumentException("Pet requires valid gender"); }

        Integer weight = values.getAsInteger(PetEntry.COLUMN__PET_WEIGHT);        if (weight != null && weight < 0) {            throw new IllegalArgumentException("Pet requires valid weight"); }

        SQLiteDatabase database = petDbHelper.getWritableDatabase();

        long id = database.insert(PetEntry.TABLE_NAME, null, values);        if (id == -1) {            Log.e(LOG_TAG, "Failed to insert row for " + uri);            return null;        }

        getContext().getContentResolver().notifyChange(uri,null);        return ContentUris.withAppendedId(uri, id);    }

    @Override    public int delete( Uri uri,  String selection,String[] selectionArgs) {        int rowsDeleted;

        SQLiteDatabase database = petDbHelper.getWritableDatabase();

        final int match = matcher.match(uri);        switch (match) {            case PETS:                rowsDeleted = database.delete(PetEntry.TABLE_NAME, selection, selectionArgs);                break;            case PETS_ID:                selection = PetEntry._ID + "=?";                selectionArgs = new String[]{String.valueOf(ContentUris.parseId(uri))};                rowsDeleted = database.delete(PetEntry.TABLE_NAME, selection, selectionArgs);                break;            default:                throw new IllegalArgumentException("Deletion is not supported for " + uri);        }

        if (rowsDeleted != 0) {            getContext().getContentResolver().notifyChange(uri, null);        }        return rowsDeleted;

    }

    @Override    public int update( Uri uri,  ContentValues values,  String selection,  String[] selectionArgs) {        final int match = matcher.match(uri);        switch (match) {            case PETS:                return updatePet(uri, values, selection, selectionArgs);            case PETS_ID:                selection = PetEntry._ID + "=?";                selectionArgs = new String[]{String.valueOf(ContentUris.parseId(uri))};                return updatePet(uri, values, selection, selectionArgs);            default:                throw new IllegalArgumentException("Update is not supported for " + uri);        }    }

    private int updatePet(Uri uri, ContentValues values, String selection, String[] selectionArgs) {

        if (values.containsKey(PetEntry.COLUMN__PET_NAME)) {            String name = values.getAsString(PetEntry.COLUMN__PET_NAME);            if (name == null) {                throw new IllegalArgumentException("Pet requires a name"); } }

        if (values.containsKey(PetEntry.COLUMN__PET_GENDER)) {            Integer gender = values.getAsInteger(PetEntry.COLUMN__PET_GENDER);            if (gender == null || !PetEntry.isValidGender(gender)) {                throw new IllegalArgumentException("Pet requires valid gender"); } }

        if (values.containsKey(PetEntry.COLUMN__PET_WEIGHT)) {            Integer weight = values.getAsInteger(PetEntry.COLUMN__PET_WEIGHT);            if (weight != null && weight < 0) {                throw new IllegalArgumentException("Pet requires valid weight"); } }

        if (values.size() == 0) {            return 0; }

        SQLiteDatabase database = petDbHelper.getWritableDatabase();        int rowsUpdated = database.update(PetEntry.TABLE_NAME, values, selection, selectionArgs);

        if (rowsUpdated != 0) {            getContext().getContentResolver().notifyChange(uri, null); }

        return rowsUpdated;    }

    @Override    public String getType( Uri uri) {        final int match = matcher.match(uri);        switch (match) {            case PETS:                return PetEntry.CONTENT_LIST_TYPE;            case PETS_ID:                return PetEntry.CONTENT_ITEM_TYPE;            default:                throw new IllegalStateException("Unknown URI " + uri + " with match " + match);        }

    }

}
github项目源码: https://github.com/NeoWu55/Android-Pets

SQLiteOpenHelper+ContentProvider的使用的更多相关文章

  1. ContentResolver + SqliteOpenHelper + ContentProvider 理解

    惭愧,现在才接触到ContentResolver的用法 这个类主要是Android用来实现应用程序之间数据共享的 一个应用程序可以将自己的数据完全暴露出去,外界更本看不到,也不用看到这个应用程序暴露的 ...

  2. Android之ContentProvider数据存储

    一.ContentProvider保存数据介绍 一个程序可以通过实现一个ContentProvider的抽象接口将自己的数据完全暴露出去,而且ContentProvider是以类似数据库中表的方式将数 ...

  3. Xamarin.Android之ContentProvider

    一.前言 掌握了如何使用SQLiteOpenHelper之后,我们就可以进行下一步的学习.本章我们将会学习如何使用ContentProvider来将数据库方面的操作封装起来,同时它还可以供其他应用访问 ...

  4. ContentProvider域名替换小工具

    开发项目域名想怎么换就怎么换,就是这么任性! 这是一个很有意思的小工具! 这是一个方便开发人员和测试人员的小工具!! 吐槽: 一直在做Android开发,一直总有一个问题存在:做自己公司的apk开发时 ...

  5. 简单的学习心得:网易云课堂Android开发第六章SQLite与ContentProvider

    一.SQLite 1.基本操作: (1)创建数据库:在SQLiteOpenHelper的子类构造器中创建. (2)创建表:在SQLiteOpenHelper的子类onCreate方法中,调用execS ...

  6. 安卓初級教程(3):ContentProvider的運用原理

    package com.example.android.provider; import java.util.ArrayList; import java.util.HashMap; import j ...

  7. Android笔记——SQLiteOpenHelper类

    public 抽象类 SQLiteOpenHelper 继承关系 Java.lang.Object android.database.sqlite.SQLiteOpenHelper 类概要 这是一个辅 ...

  8. Android细笔记--ContentProvider

    Provider的不常见访问方式 Batch access:访问ContentProvider的一中模式,使用该模式可以同时对provider进行多个操作,且支持同时操作多个表.使用时首先构建一个Co ...

  9. Android四大组件--ContentProvider详解(转)

    一.相关ContentProvider概念解析: 1.ContentProvider简介在Android官方指出的Android的数据存储方式总共有五种,分别是:Shared Preferences. ...

随机推荐

  1. Java 学习笔记 使用synchronized实现生产者消费者模式

    说明 Object.wait()使当前的线程进入到等待状态(进入到等待队列) Object.notifyAll() 唤醒等待中的全部线程 Object.notify() 随机唤醒一个线程 代码 con ...

  2. 【学习笔记】tensorflow基础

    目录 认识Tensorflow Tensorflow特点 下载以及安装 Tensorflow初体验 Tensorflow进阶 图 op 会话 Feed操作 张量 变量 可视化学习Tensorboard ...

  3. 多线程(5)async&await

    .net 4.0的Task已经让我们可以非常简单地使用多线程,并且可以有返回值,也可以支持线程的取消等操作,可谓已经很强大了.但.net 4.5为我们带来了async&await,使得实现多线 ...

  4. js之正则的坑

    首先给一个神奇的图: 我的反应,精分吧!一会儿true一会儿false的... 后来发现,把g去掉后就正常了,那这是为什么呢??lastIndex惹得鬼! 正文: lastIndex 全局正则表达是, ...

  5. js事件冒泡机制

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. loj#6073. 「2017 山东一轮集训 Day5」距离(费用流)

    题意 题目链接 Sol 我们可以把图行列拆开,同时对于行/列拆成很多个联通块,然后考虑每个点所在的行联通块/列联通块的贡献. 可以这样建边 从S向每个行联通块连联通块大小条边,每条边的容量为1,费用为 ...

  7. 章节九、2-使用firefoxdriver浏览器进行自动化测试

    一.演示如何使用火狐浏览器打开“百度” package basicweb; import org.openqa.selenium.WebDriver; import org.openqa.seleni ...

  8. nexus3.X环境搭建

    nexus3比以前的版本相比 多支持了管理不同的格式 比如Docker npm NuGet maven …等 下载编译好的二进制安装 wget https://sonatype-download.gl ...

  9. windows下安装MongoDB扩展和配置

    windows下安装MongoDB扩展和配置 1.下载mongoDB扩展,根据当前php版本进行下载 地址如下:http://pecl.php.net/package/mongo 我本地php版本是 ...

  10. GO语言学习笔记(一)

    GO语言学习笔记 1.数组切片slice:可动态增长的数组 2.错误处理流程关键字:defer panic recover 3.变量的初始化:以下效果一样 `var a int = 10` `var ...