SQLiteOpenHelper+ContentProvider的使用
效果图:

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的使用的更多相关文章
- ContentResolver + SqliteOpenHelper + ContentProvider 理解
惭愧,现在才接触到ContentResolver的用法 这个类主要是Android用来实现应用程序之间数据共享的 一个应用程序可以将自己的数据完全暴露出去,外界更本看不到,也不用看到这个应用程序暴露的 ...
- Android之ContentProvider数据存储
一.ContentProvider保存数据介绍 一个程序可以通过实现一个ContentProvider的抽象接口将自己的数据完全暴露出去,而且ContentProvider是以类似数据库中表的方式将数 ...
- Xamarin.Android之ContentProvider
一.前言 掌握了如何使用SQLiteOpenHelper之后,我们就可以进行下一步的学习.本章我们将会学习如何使用ContentProvider来将数据库方面的操作封装起来,同时它还可以供其他应用访问 ...
- ContentProvider域名替换小工具
开发项目域名想怎么换就怎么换,就是这么任性! 这是一个很有意思的小工具! 这是一个方便开发人员和测试人员的小工具!! 吐槽: 一直在做Android开发,一直总有一个问题存在:做自己公司的apk开发时 ...
- 简单的学习心得:网易云课堂Android开发第六章SQLite与ContentProvider
一.SQLite 1.基本操作: (1)创建数据库:在SQLiteOpenHelper的子类构造器中创建. (2)创建表:在SQLiteOpenHelper的子类onCreate方法中,调用execS ...
- 安卓初級教程(3):ContentProvider的運用原理
package com.example.android.provider; import java.util.ArrayList; import java.util.HashMap; import j ...
- Android笔记——SQLiteOpenHelper类
public 抽象类 SQLiteOpenHelper 继承关系 Java.lang.Object android.database.sqlite.SQLiteOpenHelper 类概要 这是一个辅 ...
- Android细笔记--ContentProvider
Provider的不常见访问方式 Batch access:访问ContentProvider的一中模式,使用该模式可以同时对provider进行多个操作,且支持同时操作多个表.使用时首先构建一个Co ...
- Android四大组件--ContentProvider详解(转)
一.相关ContentProvider概念解析: 1.ContentProvider简介在Android官方指出的Android的数据存储方式总共有五种,分别是:Shared Preferences. ...
随机推荐
- Java开发笔记(五十九)Java8之后的扩展接口
前面介绍了接口的基本用法,有心的朋友可能注意到这么一句话“在Java8以前,接口内部的所有方法都必须是抽象方法”,如此说来,在Java8之后,接口的内部方法也可能不是抽象方法了吗?之所以Java8对接 ...
- mybatis基础(下)
mybatis和spring整合 需要spring通过单例方式管理SqlSessionFactory spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSe ...
- JavaWeb - 模仿SpringMVC抽取 BaseServlet + 封装表单参数
模仿SpringMVC抽取一个BaseServlet,接收所有请求,然后自动封装表单参数和分发到对应的servlet执行,下面用一个页面表单提交,转发显示的项目做示例. 1)首先准备一个Entity, ...
- 关于火狐和IE下href="javascript:void(0)"兼容性的问题
今天在开发中发现,使用如下方式的链接.在Chrome中点击后行为符合预期,但在IE下会新开标签卡(根据参考资料,Firefox中有相同问题). 经过排查,发现是href="javascrip ...
- Sublime 无法安装插件的解决办法
1,打开命令面板 Ctrl + Shift + P 输入:pi 回车 按回车后,出现异常如下图: 解决办法: 1,点击Preferences----Brows Packages ---会到安装目录 ...
- NLP&深度学习:近期趋势概述
NLP&深度学习:近期趋势概述 摘要:当NLP遇上深度学习,到底发生了什么样的变化呢? 在最近发表的论文中,Young及其同事汇总了基于深度学习的自然语言处理(NLP)系统和应用程序的一些最新 ...
- Mapbox浅析(快速入门Mapbox)
1.是什么? Mapbox是一个可以免费创建并定制个性化地图的网站. 2.了解一些基本东西 常见的 mapbox.js和mapbox-gl.js的异同点? 相同点: 1.都是由Mapbox公司推出的免 ...
- Python进阶之函数式编程
函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计 ...
- Hadoop Yarn框架详细解析
在说Hadoop Yarn之前,我们先来看看Yarn是怎样出现的.在古老的Hadoop1.0中,MapReduce的JobTracker负责了太多的工作,包括资源调度,管理众多的TaskTracker ...
- MySQL 基础知识梳理学习(五)----详解MySQL两次写的设计及实现
一 . 两次写提出的背景或要解决的问题 两次写(InnoDB Double Write)是Innodb中很独特的一个功能点.因为Innodb中的日志是逻辑的,所谓逻辑就是比如插入一条记录时,它可能会在 ...