亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Android中自定義ContentProvider實例

2020-04-11 12:06:30
字體:
來源:轉載
供稿:網友
//以下為TestBaidu
MainActivity如下:
復制代碼 代碼如下:

package cn.testbaidu;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.app.Activity;
import android.content.ContentResolver;
import android.content.ContentValues;
import android.database.Cursor;
/**
* Demo描述:
* 應用A(TestBaidu)調用另外一個應用(TestContentProvider)
* 中的自定義ContentProvider,即:
* 1 自定義ContentProvider的使用
* 2 其它應用調用該ContentProvider
*
* 測試方法:
* 1 依次測試ContentProvider的增查刪改(注意該順序)
* 2 其它應用查詢該ContentProvider的數據
*
*/
public class MainActivity extends Activity {
private Button mAddButton;
private Button mDeleteButton;
private Button mUpdateButton;
private Button mQueryButton;
private Button mTypeButton;
private ContentResolver mContentResolver;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
init();
}
private void init() {
mContentResolver=this.getContentResolver();

mAddButton=(Button) findViewById(R.id.addButton);
mAddButton.setOnClickListener(new ClickListenerImpl());

mDeleteButton=(Button) findViewById(R.id.deleteButton);
mDeleteButton.setOnClickListener(new ClickListenerImpl());

mUpdateButton=(Button) findViewById(R.id.updateButton);
mUpdateButton.setOnClickListener(new ClickListenerImpl());

mQueryButton=(Button) findViewById(R.id.queryButton);
mQueryButton.setOnClickListener(new ClickListenerImpl());

mTypeButton=(Button) findViewById(R.id.typeButton);
mTypeButton.setOnClickListener(new ClickListenerImpl());

}
private class ClickListenerImpl implements OnClickListener{
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.addButton:
Person person=null;
for (int i = 0; i < 5; i++) {
person=new Person("xiaoming"+i, "9527"+i,(8888+i));
testInsert(person);
}
break;
case R.id.deleteButton:
testDelete(1);
break;
case R.id.updateButton:
testUpdate(3);
break;
case R.id.queryButton:
//查詢表
//queryFromContentProvider(-1);

//查詢personid=2的數據
testQuery(2);
break;
case R.id.typeButton:
testType();
break;
default:
break;
}

}

}
private void testInsert(Person person) {
ContentValues contentValues=new ContentValues();
contentValues.put("name", person.getName());
contentValues.put("phone", person.getPhone());
contentValues.put("salary",person.getSalary());
Uri insertUri=Uri.parse("content://cn.bs.testcontentprovider/person");
Uri returnUri=mContentResolver.insert(insertUri, contentValues);
System.out.println("新增數據:returnUri="+returnUri);
}

private void testDelete(int index){
Uri uri=Uri.parse("content://cn.bs.testcontentprovider/person/"+String.valueOf(index));
mContentResolver.delete(uri, null, null);
}

private void testUpdate(int index){
Uri uri=Uri.parse("content://cn.bs.testcontentprovider/person/"+String.valueOf(index));
ContentValues values=new ContentValues();
values.put("name", "hanmeimei");
values.put("phone", "1234");
values.put("salary", 333);
mContentResolver.update(uri, values, null, null);
}
private void testQuery(int index) {
Uri uri=null;
if (index<=0) {
//查詢表
uri=Uri.parse("content://cn.bs.testcontentprovider/person");
} else {
//按照id查詢某條數據
uri=Uri.parse("content://cn.bs.testcontentprovider/person/"+String.valueOf(index));
}

//對應上面的:查詢表
//Cursor cursor= mContentResolver.query(uri, null, null, null, null);

//對應上面的:查詢personid=2的數據
//注意:因為name是varchar字段的,所以應該寫作"name='xiaoming1'"
// 若寫成"name=xiaoming1"查詢時會報錯
Cursor cursor= mContentResolver.query(uri, null, "name='xiaoming1'", null, null);

while(cursor.moveToNext()){
int personid=cursor.getInt(cursor.getColumnIndex("personid"));
String name=cursor.getString(cursor.getColumnIndex("name"));
String phone=cursor.getString(cursor.getColumnIndex("phone"));
int salary=cursor.getInt(cursor.getColumnIndex("salary"));
System.out.println("查詢得到:personid=" + personid+",name="+name+",phone="+phone+",salary="+salary);
}
cursor.close();
}

private void testType(){
Uri dirUri=Uri.parse("content://cn.bs.testcontentprovider/person");
String dirType=mContentResolver.getType(dirUri);
System.out.println("dirType:"+dirType);

Uri itemUri=Uri.parse("content://cn.bs.testcontentprovider/person/3");
String itemType=mContentResolver.getType(itemUri);
System.out.println("itemType:"+itemType);
}
}

Person如下:
復制代碼 代碼如下:

package cn.testbaidu;
public class Person {
private Integer id;
private String name;
private String phone;
private Integer salary;
public Person(String name, String phone,Integer salary) {
this.name = name;
this.phone = phone;
this.salary=salary;
}
public Person(Integer id, String name, String phone,Integer salary) {
this.id = id;
this.name = name;
this.phone = phone;
this.salary=salary;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public Integer getSalary() {
return salary;
}
public void setSalary(Integer salary) {
this.salary = salary;
}
@Override
public String toString() {
return "Person [id=" + id + ", name=" + name + ", phone=" + phone+ ", salary=" + salary + "]";
}



}

main.xml如下:
復制代碼 代碼如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<Button
android:id="@+id/addButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="30dip"
android:text="增加"
android:textSize="20sp" />
<Button
android:id="@+id/deleteButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="30dip"
android:layout_below="@id/addButton"
android:text="刪除"
android:textSize="20sp" />
<Button
android:id="@+id/updateButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="30dip"
android:layout_below="@id/deleteButton"
android:text="修改"
android:textSize="20sp" />
<Button
android:id="@+id/queryButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="30dip"
android:layout_below="@id/updateButton"
android:text="查詢"
android:textSize="20sp" />
<Button
android:id="@+id/typeButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="30dip"
android:layout_below="@id/queryButton"
android:text="類型"
android:textSize="20sp" />
</RelativeLayout>

//以下為TestContentProvider
MainActivity如下:
復制代碼 代碼如下:

package cn.testcontentprovider;
import android.app.Activity;
import android.os.Bundle;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
}

ContentProviderTest如下:
復制代碼 代碼如下:

package cn.testcontentprovider;
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;
/**
* 注意事項:
* 在AndroidManifest.xml中注冊ContentProvider時的屬性
* android:exported="true"表示允許其他應用訪問.
* 這樣TestBaidu這個應用才可以訪問該處的ContentProvider
*/
public class ContentProviderTest extends ContentProvider {
private DBOpenHelper dbOpenHelper;
private UriMatcher URI_MATCHER;
private static final int PERSONS = 0;
private static final int PERSON = 1;

@Override
public boolean onCreate() {
initUriMatcher();
dbOpenHelper=new DBOpenHelper(getContext());
return true;
}
//初始化UriMatcher
private void initUriMatcher(){
URI_MATCHER=new UriMatcher(UriMatcher.NO_MATCH);
//表示返回所有的person,其中PERSONS為該特定Uri的標識碼
URI_MATCHER.addURI("cn.bs.testcontentprovider","person", PERSONS);
//表示返回某一個person,其中PERSON為該特定Uri的標識碼
URI_MATCHER.addURI("cn.bs.testcontentprovider","person/#", PERSON);
}
/**
* 插入操作:
* 插入操作只有一種可能:向一張表中插入
* 返回結果為新增記錄對應的Uri
* 方法db.insert()返回結果為新增記錄對應的主鍵值
*/
@Override
public Uri insert(Uri uri, ContentValues values) {
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
switch (URI_MATCHER.match(uri)) {
case PERSONS:
long rowid=db.insert("person", "name,phone,salary", values);
return ContentUris.withAppendedId(uri, rowid);
default:
throw new IllegalArgumentException("unknown uri"+uri.toString());
}
}

/**
* 更新操作:
* 更新操作有兩種可能:更新一張表或者更新某條數據
* 在更新某條數據時原理類似于查詢某條數據,見下.
*/
@Override
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
int updataNum=0;
switch (URI_MATCHER.match(uri)) {
//更新表
case PERSONS:
updataNum=db.update("person", values, selection, selectionArgs);
break;
//按照id更新某條數據
case PERSON:
long id=ContentUris.parseId(uri);
String where="personid="+id;
if(selection!=null&&!"".equals(selection.trim())){
where=selection+" and "+where;
}
updataNum=db.update("person", values, where, selectionArgs);
break;
default:
throw new IllegalArgumentException("unknown uri"+uri.toString());
}
return updataNum;
}

/**
* 刪除操作:
* 刪除操作有兩種可能:刪除一張表或者刪除某條數據
* 在刪除某條數據時原理類似于查詢某條數據,見下.
*/
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
int deletedNum=0;
switch (URI_MATCHER.match(uri)) {
//刪除表
case PERSONS:
deletedNum=db.delete("person", selection, selectionArgs);
break;
//按照id刪除某條數據
case PERSON:
long id=ContentUris.parseId(uri);
String where="personid="+id;
if(selection!=null&&!"".equals(selection.trim())){
where=selection+" and "+where;
}
deletedNum=db.delete("person", where, selectionArgs);
break;
default:
throw new IllegalArgumentException("unknown uri"+uri.toString());
}
return deletedNum;
}
/**
* 查詢操作:
* 查詢操作有兩種可能:查詢一張表或者查詢某條數據
* 注意事項:
* 在查詢某條數據時要注意--因為此處是按照personid來查詢
* 某條數據,但是同時可能還有其他限制.例如:
* 要求personid為2且name為xiaoming1
* 所以在查詢時分為兩步:
* 第一步:
* 解析出personid放入where查詢條件
* 第二部:
* 判斷是否有其他限制(如name),若有則將其
* 組拼到where查詢條件.
* 詳細代碼見下.
*/
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
SQLiteDatabase db=dbOpenHelper.getWritableDatabase();
Cursor cursor;
switch (URI_MATCHER.match(uri)) {
//查詢表
case PERSONS:
cursor=db.query("person", projection, selection, selectionArgs, null, null, sortOrder);
break;
//按照id查詢某條數據
case PERSON:
//第一步:
long id=ContentUris.parseId(uri);
String where="personid="+id;
//第二步:
if(selection!=null&&!"".equals(selection.trim())){
where=selection+" and "+where;
}
cursor=db.query("person", projection, where, selectionArgs, null, null, sortOrder);
break;
default:
throw new IllegalArgumentException("unknown uri"+uri.toString());
}
return cursor;
}

/**
* 返回當前Uri所代表的數據的MIME類型.
* 如果該Uri對應的數據可能包含多條記錄,那么返回
* 字符串應該以"vnd.android.cursor.dir/"開頭
* 如果該Uri對應的數據只包含一條記錄,那么返回
* 字符串應該以"vnd.android.cursor.item/"開頭
*/
@Override
public String getType(Uri uri) {
switch (URI_MATCHER.match(uri)) {
case PERSONS:
return "vnd.android.cursor.dir/persons";
case PERSON:
return "vnd.android.cursor.item/person";
default:
throw new IllegalArgumentException("unknown uri"+uri.toString());
}
}
}

DBOpenHelper如下:
復制代碼 代碼如下:

package cn.testcontentprovider;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DBOpenHelper extends SQLiteOpenHelper {
public DBOpenHelper(Context context) {
super(context, "contentprovidertest.db", null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table person(personid integer primary key autoincrement,name varchar(20),phone varchar(12),salary Integer(12))");
}
//當數據庫版本號發生變化時調用該方法
@Override
public void onUpgrade(SQLiteDatabase db, int arg1, int arg2) {
//db.execSQL("ALTER TABLE person ADD phone varchar(12) NULL");
//db.execSQL("ALTER TABLE person ADD salary Integer NULL");
}
}

AndroidManifest.xml如下:
復制代碼 代碼如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="cn.testcontentprovider"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="8" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="cn.testcontentprovider.MainActivity"
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:name="cn.testcontentprovider.ContentProviderTest"
android:authorities="cn.bs.testcontentprovider"
android:exported="true"
/>
</application>
</manifest>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产视频在线一区二区| 欧美成人精品激情在线观看| 欧美一区二区三区免费观看| 伊是香蕉大人久久| 91免费在线视频网站| 亚洲自拍偷拍网址| 欧美黄色片免费观看| 日韩经典第一页| 川上优av一区二区线观看| 欧美床上激情在线观看| 中文字幕9999| 亚洲情综合五月天| 91成人在线视频| 久久天堂电影网| 欧美高清视频一区二区| 高清欧美一区二区三区| 一本色道久久88综合日韩精品| 国产综合香蕉五月婷在线| 色yeye香蕉凹凸一区二区av| 欧美专区在线观看| 久久精品国产91精品亚洲| 亚洲在线观看视频| 91精品久久久久久久久久久久久久| 亚洲国产精品久久精品怡红院| 欧美日本高清视频| 欧美体内谢she精2性欧美| 国产精品欧美日韩久久| 成人精品视频99在线观看免费| 欧美亚洲另类视频| 日韩免费av片在线观看| 亚洲人成在线观看网站高清| 亚洲视频第一页| 成人444kkkk在线观看| 国产精品狼人色视频一区| 最近2019中文免费高清视频观看www99| 国产精品无av码在线观看| 精品毛片网大全| 欧美成人精品一区二区三区| 日韩电影免费观看中文字幕| 久久夜色精品亚洲噜噜国产mv| 91精品在线看| 蜜臀久久99精品久久久无需会员| 成人www视频在线观看| 欧美超级乱淫片喷水| 91在线观看欧美日韩| 91综合免费在线| 亚洲偷欧美偷国内偷| 国产亚洲精品久久久| 久久久久久久久久久免费| 国产日韩精品综合网站| 日韩精品在线观看一区二区| 国产精品免费小视频| 久久99久国产精品黄毛片入口| 亚洲视频欧美视频| 久久久久久亚洲精品不卡| 日韩高清电影免费观看完整版| 色综合天天综合网国产成人网| 亚洲精品www久久久| 成人久久一区二区| 色综合亚洲精品激情狠狠| 日本亚洲欧美三级| 这里只有精品视频在线| 国产精品久久久久久久久久久不卡| 色婷婷久久av| 欧美色欧美亚洲高清在线视频| 精品国产欧美一区二区五十路| 中文字幕日韩在线播放| 亚洲欧美www| 久久激情视频免费观看| 欧美极品少妇与黑人| 久久精品这里热有精品| 国产黑人绿帽在线第一区| 亚洲欧美在线第一页| 欧美精品videossex性护士| 91夜夜揉人人捏人人添红杏| 国产午夜精品一区理论片飘花| 久久国产精品久久久| 欧美成人网在线| www国产亚洲精品久久网站| 伊人青青综合网站| 日韩在线免费av| 精品久久久久久亚洲精品| 欧美午夜性色大片在线观看| 国产z一区二区三区| 亚洲视屏在线播放| 久久韩剧网电视剧| 欧美日韩亚洲一区二区| 午夜精品久久久久久99热软件| 日韩中文字幕免费| 中文字幕久久久| 欧美精品www| 欧美裸体xxxx极品少妇| 国产不卡av在线免费观看| 成人精品视频在线| 97久久精品在线| 国产欧美在线观看| 亚洲国产精品va在线看黑人动漫| 91精品国产高清久久久久久91| 欧洲日本亚洲国产区| 国产日韩中文在线| 萌白酱国产一区二区| 中文字幕国产精品久久| 国产原创欧美精品| 精品亚洲一区二区三区四区五区| 欧美日韩电影在线观看| 国产一区私人高清影院| 亚洲福利在线视频| 亚洲免费视频一区二区| 久久久av电影| 91精品国产高清| 欧美另类老女人| 国产精品一久久香蕉国产线看观看| 精品久久久久久久久久久久久久| 欧美成人精品一区二区三区| 在线视频欧美日韩精品| 日韩精品极品毛片系列视频| 亚洲欧美日韩直播| 青青草一区二区| 欧美精品免费在线观看| 日韩欧美国产成人| 成人福利网站在线观看| 伦理中文字幕亚洲| 国产精品爽爽爽爽爽爽在线观看| 91高清在线免费观看| 51色欧美片视频在线观看| 国产日韩欧美在线观看| 91免费国产视频| 久久久成人精品视频| 日韩一区视频在线| 欧美精品在线免费观看| 国产精品一区二区av影院萌芽| 日韩欧美国产免费播放| 国内揄拍国内精品少妇国语| 精品视频在线播放免| 精品久久久国产精品999| 高清欧美性猛交xxxx黑人猛交| 欧美激情一区二区三区高清视频| 久久精品国产一区二区三区| 久久精品在线播放| 国产综合久久久久久| 欧美福利视频网站| 亚洲欧美国产另类| 亚洲丁香婷深爱综合| 国产精品盗摄久久久| 日韩免费在线观看视频| 国产精品入口福利| 亚洲精品久久7777777| 亚洲激情视频在线观看| 久久夜色精品亚洲噜噜国产mv| 亚洲精品丝袜日韩| 欧美国产日韩一区二区| 日韩电影中文 亚洲精品乱码| 国产精品久久91| 久久影院中文字幕| 亚洲成人黄色在线| 欧美在线视频在线播放完整版免费观看| 91沈先生作品| 日本精品性网站在线观看| 国产精品青青在线观看爽香蕉| 中文字幕久久久av一区| 国内免费精品永久在线视频| 亚洲精品小视频在线观看| 国产a级全部精品| 国产精品视频免费在线观看|