`
艳过留痕
  • 浏览: 40534 次
社区版块
存档分类

ContentProvide 共享数据库 (附源代码)

阅读更多
1、ContentProvider的基本概念
     1> ContentProvider为存储和读取数据提供了统一的接口
     2> 使用ContentProvider,应用程序可以实现数据共享
     3> android内置的许多数据都是使用ContentProvider形式,供开发者调用的(如视频,音频,图片,通讯录等)
2、Uri
     1> 每一个ContentProvider都拥有一个公共的Uri,这个Uri用于表示这个ContentProvider提供的数据
     2> Android所提供的ContentProvider都存放在andriod.provider这个包里面
3、ContentProvider提供的函数
     1> query() 查询
     2> insert() 插入
     3> update() 更新
     4> delete() 删除
   5> getType() 得到数据类型
     6> onCreate() 创建时的回调函数
4、实现ContentProvider的过程
    1> 定义一个COTENT_URI常量
    2> 定义一个类,继承ContentProvider
    3> 实现query(),delete(),update(),insert(),onCreate(),getType()方法
    4> 在AndroidMainfest.xml中申明
下面以两个实例(一个是ContentProvider所在的应用,另一个是使用ContentProvider的应用),说明如何使用ContentProvider
5、ContentProvider所在的应用
package com.zy.namespace;
 
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.widget.Toast;

public class MyContentDemo extends Activity {

    @Override 
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
//        setContentView(R.layout.main);
        insertRecord("MyUser");
        insertRecord("YangYuLin");
        displayRecords();
    }

    private void insertRecord(String userName) {
        ContentValues values = new ContentValues();
        values.put(MyUsers.User.USER_NAME, userName);
        getContentResolver().insert(MyUsers.User.CONTENT_URI, values);
    }

    private void displayRecords() {
        String columns[] = new String[] { MyUsers.User._ID,
                MyUsers.User.USER_NAME };
        Uri myUri = MyUsers.User.CONTENT_URI;
        Cursor cur = managedQuery(myUri, columns, null, null, null);
        if (cur.moveToFirst()) {
            String id = null;
            String userName = null;
            do {
                id = cur.getString(cur.getColumnIndex(MyUsers.User._ID));
                userName = cur.getString(cur
                        .getColumnIndex(MyUsers.User.USER_NAME));
//                Toast.makeText(this, id + " " + userName, Toast.LENGTH_LONG)
//                        .show();
                System.out.println("_111id = " + id +", 111user_name = " + userName);
            } while (cur.moveToNext());
        }
    }
}
 

package com.zy.namespace;

import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteQueryBuilder;
import android.net.Uri;


/*
 * MyContentProvider继承ContentProvider类,实现其insert,update,delete,getType,onCreate等方法
 */
public class MyContentProvider extends ContentProvider {

    //定义一个SQLiteDatabase变量
    private SQLiteDatabase sqlDB;
    //定义一个DatabaseHelper变量
    private DatabaseHelper dbHelper;
    //数据库名
    private static final String DATABASE_NAME = "Users.db";
    //数据库版本
    private static final int DATABASE_VERSION = 1;
    //表名
    private static final String TABLE_NAME = "User";
    //标签
    private static final String TAG = "MyContentProvider";

    /*
     * 定义一个内部类
     * 
     * 这个内部类继承SQLiteOpenHelper类,重写其方法
     */
    public static class DatabaseHelper extends SQLiteOpenHelper {

        //构造方法
        public DatabaseHelper(Context context) {
            //父类构造方法
            super(context, DATABASE_NAME, null, DATABASE_VERSION);
        }

        //当第一次创建数据库的时候调用该方法,可以为数据库增加一些表,和初始化一些数据
        @Override
        public void onCreate(SQLiteDatabase db) {
            //在数据库里生成一张表
            db.execSQL("Create table "
                    + TABLE_NAME
                    + "( _id INTEGER PRIMARY KEY AUTOINCREMENT, USER_NAME TEXT);");
        }

        //当更新数据库版本的时候,调用该方法。可以删除,修改表的一些信息
        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
            onCreate(db);

        }

    }

    //这是一个回调函数,当生成所在类的对象时,这个方法被调用,创建一个数据库
    @Override
    public boolean onCreate() {
        dbHelper = new DatabaseHelper(getContext());
        return (dbHelper == null) ? false : true;
    }

    //查询
    @Override
    public Cursor query(Uri uri, String[] projection, String selection,
            String[] selectionArgs, String sortOrder) {
        SQLiteQueryBuilder qb = new SQLiteQueryBuilder();
        SQLiteDatabase db = dbHelper.getReadableDatabase();
        qb.setTables(TABLE_NAME);
        Cursor c = qb.query(db, projection, selection, null, null, null,
                sortOrder);
        c.setNotificationUri(getContext().getContentResolver(), uri);
        return c;
    }

    //取得类型
    @Override
    public String getType(Uri uri) {
        return null;
    }

    //插入数据
    @Override
    public Uri insert(Uri uri, ContentValues contentvalues) {
        sqlDB = dbHelper.getWritableDatabase();
        long rowId = sqlDB.insert(TABLE_NAME, "", contentvalues);
        if (rowId > 0) {
            Uri rowUri = ContentUris.appendId(
                    MyUsers.User.CONTENT_URI.buildUpon(), rowId).build();
            getContext().getContentResolver().notifyChange(rowUri, null);
            return rowUri;
        }
        throw new SQLException("Failed to insert row into" + uri);
    }

    //删除数据
    @Override
    public int delete(Uri uri, String selection, String[] selectionArgs) {
        return 0;
    }

    //更新数据
    @Override
    public int update(Uri uri, ContentValues values, String selection,
            String[] selectionArgs) {
        return 0;
    }

}
 


package com.zy.namespace;

import android.net.Uri;
import android.provider.BaseColumns;

public class MyUsers {
    
    public static final String AUTHORITY = "com.zy.namespace.MyContentProvider";
    
    //BaseColumn类中已经包含了_id字段
    public static final class User implements BaseColumns
    {
        //定义Uri
        public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY);
        //定义数据表列
        public static final String USER_NAME = "USER_NAME";
    }

}
 



 

package com.z.name;


import android.app.Activity;
import android.content.ContentResolver;
import android.content.ContentValues;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class CPClientActitity extends Activity {
   
    public static final String AUTHORITY = "com.zy.namespace.MyContentProvider";    
    private Button insertButton = null;
    //访问ContentProvider的Uri
    Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY);
    
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        Uri CONTENT_URI1 = Uri.parse("content://com.zy.namespace.MyContentProvider");
        String columns[] = new String[] { "_id","USER_NAME"};
        Cursor c = managedQuery(CONTENT_URI1, columns, null, null, null);
        if (c.moveToFirst()) {
            String id = null;
            String userName = null;
            do {
                id = c.getString(c.getColumnIndex("_id"));
                userName = c.getString(c.getColumnIndex("USER_NAME"));
//                Toast.makeText(this, id + " " + userName, Toast.LENGTH_LONG)
//                        .show();
                System.out.println("_id = " + id +", user_name = " + userName);
            } while (c.moveToNext());
        }
        
    /*    //得到ContentProvider对于表的所有数据,以游标格式保存
        Cursor c = managedQuery(CONTENT_URI,new String[]{"_id","USER_NAME"},null,null,null);
        
        //循环打印ContentProvider的数据
        if(c.moveToFirst())
        {
            String _id = null;
            String user_name = null;
            
            do
            {
                //得到_id列,USER_NAME列
                _id = c.getString(c.getColumnIndex("_id"));
                user_name = c.getString(c.getColumnIndex("USER_NAME"));
                
                System.out.println("_id = " + _id +", user_name = " + user_name);
                
            }while(c.moveToNext());
        }*/
        
        //根据Id得到控件对象
        insertButton = (Button)findViewById(R.id.Insert);
        //给按钮绑定事件监听器
        insertButton.setOnClickListener(new View.OnClickListener() {
            
            @Override
            public void onClick(View v) {
                
                //得到EditText输入的数据
                String username = ((EditText)findViewById(R.id.userName)).getText().toString();
                //生成一个ContentResolver对象
                ContentResolver cr = getContentResolver();
                //生成一个ContentValues对象
                ContentValues values = new ContentValues();
                //将EditText输入的值,保存到ContentValues对象中
                values.put("USER_NAME", username);                
                //插入数据
                cr.insert(CONTENT_URI, values);
            }
        });
    }
}
 

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.zy.namespace"
    android:versionCode="1"
    android:versionName="1.0" >

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <provider
            android:name=".MyContentProvider"
            android:authorities="com.zy.namespace.MyContentProvider" />

        <activity
            android:name=".MyContentDemo"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

    <uses-sdk android:minSdkVersion="7" />

</manifest>
 
分享到:
评论

相关推荐

    Android使用ContentProvide实现数据共享

    3. **ContentContract**:定义数据模型和操作接口,包括常量(如表名、列名)以及公开的Uri常量,有助于提高代码可读性。 4. **SQLite数据库**:通常,ContentProvider会与SQLite数据库配合,将数据存储在本地。...

    contentprovide

    这个demo,是关于contentprovider的demo,contentprovider是跨进程调用数据的。以前我很不理解这个contentprovider,因此写了一个dmeo和博客加深理解,再次共享这个demo,希望能帮到和我一样的渣渣

    android contentprovide demo通俗易懂

    1. `onCreate()`: 当ContentProvider被系统启动时调用,通常在这里进行初始化工作,如数据库的创建或打开。 2. `query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder...

    android使用ContentProvide进程通信

    在Android系统中,进程间通信(IPC,Inter-Process Communication)是实现不同应用程序之间数据共享与协同工作的重要机制。ContentProvider作为Android四大组件之一,它就是专门为了解决进程间通信而设计的。在这个...

    ContentProvider如何共享数据

    下面将详细介绍如何通过 ContentProvider 实现数据共享,并给出相关代码和配置信息。 #### ContentProvider 的基本概念与作用 ContentProvider 是 Android 四大组件之一,主要负责存储和检索数据。它可以被其他...

    作业三——contentProvide、http请求和json解析

    此代码为《作业三——contentProvide、http请求和json解析》的示例代码,详情请点击http://blog.csdn.net/qq347198688/article/details/53074291查看,欢迎讨论与交流!

    contentprovide删除联系人短信

    在Android系统中,ContentProvider是Android提供的一种数据共享机制,允许不同的应用之间交换和操作数据。本主题将深入探讨如何使用ContentProvider来查询并删除联系人以及与之相关的短信。首先,我们需要理解...

    Android使用ContentProvide实现的建议联系人读取(7.11环境)

    在Android系统中,ContentProvider是四大组件之一,它充当了数据共享和访问的桥梁,使得应用程序之间能够安全地共享数据。本示例聚焦于如何在Android 7.11环境下利用ContentProvider读取建议的联系人信息,包括通话...

    ContentProvider获取系统的图片视频和音频

    在Android系统中,ContentProvider是四大组件之一,它扮演着数据共享的角色,使得不同应用程序之间可以安全地访问和操作彼此的数据。本篇文章将详细讲解如何使用ContentProvider通过ContentResolver来获取系统的图片...

    《移动互联网开发实验》教学大纲.docx

    + ContentProvide 初步设计 + 验证实验 * 实验四:拖放处理设计 + 拖放操作设计与实现 + 验证实验 四、课程考核 * 实验实习报告的撰写要求: + 撰写内容包括实验目的、实验内容、实验步骤、实验结论 + 要求...

    Android学习课件

    通过ContentProvider,开发者可以实现对SQLite数据库、文件系统等数据源的操作,并提供统一的接口供其他组件调用。 除了四大组件,还有一些重要的控件和概念: - **Intent**:Intent是Android中对象间通信的重要...

    Android_Java经典笔试题及答案

    - **ContentProvider**: 提供跨程序共享数据的方法,用于访问数据库等数据源。 3. **java.io包中的** **ObjectInputStream** **和** **ObjectOutputSteam** **类主要用于对对象(Object)的读写**。 - **...

    android面试题汇总(含答案)

    **题目:** android的四大组件是activiey,service,broadcast和contentprovide。 **解析:** Android四大组件包括: - **Activity:** 代表用户交互的界面,是应用的核心。 - **Service:** 在后台运行的服务,不与...

Global site tag (gtag.js) - Google Analytics