package com.example.qunzheng.todolist.provider;

import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteQueryBuilder;
import android.net.Uri;
import android.text.TextUtils; /**
* Created by QunZheng on 2015/3/9.
*/
public class EarthquakeProvider extends ContentProvider {
public static final Uri CONTENT_URI = Uri.parse("content://com.qunzheng.earthquakeprovider/earthquakes");
public static final String KEY_ID = "_id";
public static final String KEY_DATE = "date";
public static final String KEY_DETAILS = "details";
public static final String KEY_SUMMARY = "summary";
public static final String KEY_LOCATION_LAT = "latitude";
public static final String KEY_LOCATION_LNG = "longitude";
public static final String KEY_LINK = "link";
public static final String KEY_MAGNITUDE = "magnitude"; private EarthquakeDatabaseHelper sqLiteOpenHelper = null; private static final int ALL_ROWS = 1;
private static final int SINGLE_ROW = 2; private static UriMatcher matcher = null; static {
matcher = new UriMatcher(UriMatcher.NO_MATCH);
matcher.addURI("com.qunzheng.earthquakeprovider","earthquakes",ALL_ROWS);
matcher.addURI("com.qunzheng.earthquakeprovider","earthquakes/#",SINGLE_ROW);
} @Override
public boolean onCreate() {
sqLiteOpenHelper = new EarthquakeDatabaseHelper(getContext(), EarthquakeDatabaseHelper.DATABASE_NAME, null, EarthquakeDatabaseHelper.DATABASE_VERSION);
return true;
} @Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
SQLiteDatabase db = sqLiteOpenHelper.getWritableDatabase(); SQLiteQueryBuilder queryBuilder = new SQLiteQueryBuilder();
queryBuilder.setTables(EarthquakeDatabaseHelper.DATABASE_TABLE);
switch (matcher.match(uri)) {
case SINGLE_ROW:
String rowId = uri.getPathSegments().get(1);
queryBuilder.appendWhere(KEY_ID + "=" + rowId);
break;
} String orderBy;
if (TextUtils.isEmpty(sortOrder)) {
orderBy = KEY_DATE;
}else{
orderBy = sortOrder;
}
return queryBuilder.query(db,projection,selection,selectionArgs,null,null,orderBy);
} @Override
public String getType(Uri uri) {
switch (matcher.match(uri)) {
case ALL_ROWS:
return "vnd.android.cursor.dir/vnd.qunzheng.earthquakes";
case SINGLE_ROW:
return "vnd.android.cursor.item/vnd.qunzheng.earthquakes";
default:
throw new IllegalArgumentException("Unsupport Uri:" + uri);
}
} @Override
public Uri insert(Uri uri, ContentValues values) {
SQLiteDatabase db = sqLiteOpenHelper.getWritableDatabase(); long id = db.insert(EarthquakeDatabaseHelper.DATABASE_TABLE, null, values); //数据插入成功
if (id > -1) {
Uri resultUri = ContentUris.withAppendedId(CONTENT_URI, id); getContext().getContentResolver().notifyChange(resultUri, null);
return resultUri;
}else{ }
return null;
} @Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
SQLiteDatabase db = sqLiteOpenHelper.getWritableDatabase(); switch (matcher.match(uri)) {
case SINGLE_ROW:
String id = uri.getPathSegments().get(1);
selection = KEY_ID + "=" + id +
(TextUtils.isEmpty(selection) ? "" : (" and ("+ selection +")"));
break;
} if (selection == null) {
selection = "1";
} int resultRows = db.delete(EarthquakeDatabaseHelper.DATABASE_TABLE, selection, selectionArgs); getContext().getContentResolver().notifyChange(uri, null);
return resultRows;
} @Override
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
SQLiteDatabase db = sqLiteOpenHelper.getReadableDatabase(); switch (matcher.match(uri)) {
case SINGLE_ROW:
String id = uri.getPathSegments().get(1);
selection = KEY_ID + "=" + id +
(TextUtils.isEmpty(selection) ? "" : (" and ("+ selection +")"));
break;
} int resultRows = db.update(EarthquakeDatabaseHelper.DATABASE_TABLE, values, selection, selectionArgs);
getContext().getContentResolver().notifyChange(uri, null);
return resultRows;
} private static class EarthquakeDatabaseHelper extends SQLiteOpenHelper{ public static final String DATABASE_NAME = "earthquake.db";
public static final int DATABASE_VERSION = 1;
public static final String DATABASE_TABLE = "earthQuake"; private static final String TABLE_CREATE = "create table " +
DATABASE_TABLE + " (" + KEY_ID + " integer primary key autoincrement, " +
KEY_DATE + " INTEGER, " +
KEY_LINK + " text, " +
KEY_LOCATION_LAT + " FLOAT, " +
KEY_LOCATION_LNG + " FLOAT, " +
KEY_SUMMARY + " TEXT, " +
KEY_MAGNITUDE + " FLOAT, " +
KEY_DETAILS + " text)"; public EarthquakeDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
} @Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(TABLE_CREATE);
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { }
}
}

  

contentProvider模板的更多相关文章

  1. Android proguard-rules.pro 混淆模板

    在../sdk/tools/proguard/目录下,其中包含了android最基本的混淆 ..\proguard-rules.pro  混淆文件配置模板: ############# 混淆模板 ## ...

  2. Jade模板引擎让你飞

    写在前面:现在jade改名成pug了 一.安装 npm install jade 二.基本使用 1.简单使用 p hello jade! 渲染后: <p>hello jade!</p ...

  3. ABP入门系列(2)——通过模板创建MAP版本项目

    一.从官网创建模板项目 进入官网下载模板项目 依次按下图选择: 输入验证码开始下载 下载提示: 二.启动项目 使用VS2015打开项目,还原Nuget包: 设置以Web结尾的项目,设置为启动项目: 打 ...

  4. CMS模板应用调研问卷

    截止目前,已经有数十家网站与我们合作,进行了MIP化改造,在搜索结果页也能看到"闪电标"的出现.除了改造方面的问题,MIP项目组被问到最多的就是:我用了wordpress,我用了织 ...

  5. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  6. 【原创分享·微信支付】C# MVC 微信支付之微信模板消息推送

    微信支付之微信模板消息推送                    今天我要跟大家分享的是“模板消息”的推送,这玩意呢,你说用途嘛,那还是真真的牛逼呐.原因在哪?就是因为它是依赖微信生存的呀,所以他能不 ...

  7. OpenCV模板匹配算法详解

    1 理论介绍 模板匹配是在一幅图像中寻找一个特定目标的方法之一,这种方法的原理非常简单,遍历图像中的每一个可能的位置,比较各处与模板是否“相似”,当相似度足够高时,就认为找到了我们的目标.OpenCV ...

  8. 前端MVC学习总结(一)——MVC概要与angular概要、模板与数据绑定

    一.前端MVC概要 1.1.库与框架的区别 框架是一个软件的半成品,在全局范围内给了大的约束.库是工具,在单点上给我们提供功能.框架是依赖库的.AngularJS是框架而jQuery则是库. 1.2. ...

  9. ThinkPHP+Smarty模板中截取包含中英文混合的字符串乱码的解决方案

    好几天没写博客了,其实有好多需要总结的,因为最近一直在忙着做项目,但是困惑了几天的Smarty模板中截取包含中英文混合的字符串乱码的问题,终于解决了,所以记录下来,需要的朋友看一下: 出现乱码的原因: ...

随机推荐

  1. 通过navicat连接mysql服务器提示SQL Error (1130): Host '192.168.1.100' is not allowed to connect to this MySQL server

    新装一个mysql,尝试用通过navicat连接mysql服务器的时候提示: SQL Error (1130): Host '192.168.1.100' is not allowed to conn ...

  2. linux是实时系统还是分时操作系统

    实时操作系统 实时操作系统 英文称Real Time Operating System,简称RTOS. 1.实时操作系统定义 实时操作系统(RTOS)是指当外界事件或数据产生时,能够接受并以足够快的速 ...

  3. MySQL can’t specify target table for update in FROM clause

    翻译:MySQL不能指定更新的目标表在FROM子句 源SQL语句: delete from t_official_sys_user where USER_NAME IN(SELECT USER_NAM ...

  4. BZOJ_1601_[Usaco2008_Oct]_灌水_(最小生成树_Kruskal)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1601 有\(n\)个田地需要灌溉,每个田地可以自己引水,花费为\(w[i]\),或者连接其他被 ...

  5. [swustoj 411] 售货员的难题

    售货员的难题(0411) Time limit(ms): 5000 Memory limit(kb): 65535 Submission: 1744 Accepted: 200 Description ...

  6. C#调用C++的DLL函数另一则(delegate) z

    使用DLLImport进行导入函数的事. C#调用C++的函数其实不止这一种方法, 还有一种方法是用delegate申明函数委托进行调用,这种方法略显麻烦,但是可以进行回调并应用指针. 在C#中,首先 ...

  7. SVN记住用户名和密码后如何修改

    今天遇到一个SVN检出代码用户验证问题.由于自己最近参与了好几个项目,一时间忙不过来.所以希望跟着自己的试用期的同事帮我测试一下刚修改完成的新功能是否有问题.但是该同事没有项目中权限,正好今天恰逢星期 ...

  8. Tomcat启动时为什么要配置CATALINA_HOME环境变量??

    CATALINA_HOME的值被设为Tomcat的安装目录,如果环境变量CATALINA_HOME已经存在,则通过这个环境变量调用bin目录下的“catalina.bat start”命令 1.Tom ...

  9. Already tried 0 time(s); retry policy is RetryUpToMaximumCountWithFixedSleep解决方法

    14/03/26 23:10:04 INFO ipc.Client: Retrying connect to server: 0.0.0.0/0.0.0.0:10020. Already tried ...

  10. 人工神经网络(Artificial Neural Networks)

    人工神经网络的产生一定程度上受生物学的启发,因为生物的学习系统是由相互连接的神经元相互连接的神经元组成的复杂网络.而人工神经网络跟这个差不多,它是一系列简单的单元相互密集连接而成的.其中每个单元有一定 ...