效果图:

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开发笔记(五十九)Java8之后的扩展接口

    前面介绍了接口的基本用法,有心的朋友可能注意到这么一句话“在Java8以前,接口内部的所有方法都必须是抽象方法”,如此说来,在Java8之后,接口的内部方法也可能不是抽象方法了吗?之所以Java8对接 ...

  2. mybatis基础(下)

    mybatis和spring整合 需要spring通过单例方式管理SqlSessionFactory spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSe ...

  3. JavaWeb - 模仿SpringMVC抽取 BaseServlet + 封装表单参数

    模仿SpringMVC抽取一个BaseServlet,接收所有请求,然后自动封装表单参数和分发到对应的servlet执行,下面用一个页面表单提交,转发显示的项目做示例. 1)首先准备一个Entity, ...

  4. 关于火狐和IE下href="javascript:void(0)"兼容性的问题

    今天在开发中发现,使用如下方式的链接.在Chrome中点击后行为符合预期,但在IE下会新开标签卡(根据参考资料,Firefox中有相同问题). 经过排查,发现是href="javascrip ...

  5. Sublime 无法安装插件的解决办法

    1,打开命令面板 Ctrl + Shift + P  输入:pi  回车 按回车后,出现异常如下图: 解决办法: 1,点击Preferences----Brows Packages ---会到安装目录 ...

  6. NLP&深度学习:近期趋势概述

    NLP&深度学习:近期趋势概述 摘要:当NLP遇上深度学习,到底发生了什么样的变化呢? 在最近发表的论文中,Young及其同事汇总了基于深度学习的自然语言处理(NLP)系统和应用程序的一些最新 ...

  7. Mapbox浅析(快速入门Mapbox)

    1.是什么? Mapbox是一个可以免费创建并定制个性化地图的网站. 2.了解一些基本东西 常见的 mapbox.js和mapbox-gl.js的异同点? 相同点: 1.都是由Mapbox公司推出的免 ...

  8. Python进阶之函数式编程

    函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计 ...

  9. Hadoop Yarn框架详细解析

    在说Hadoop Yarn之前,我们先来看看Yarn是怎样出现的.在古老的Hadoop1.0中,MapReduce的JobTracker负责了太多的工作,包括资源调度,管理众多的TaskTracker ...

  10. MySQL 基础知识梳理学习(五)----详解MySQL两次写的设计及实现

    一 . 两次写提出的背景或要解决的问题 两次写(InnoDB Double Write)是Innodb中很独特的一个功能点.因为Innodb中的日志是逻辑的,所谓逻辑就是比如插入一条记录时,它可能会在 ...