ContentProvider 系统URI

本文详细介绍了如何使用ContentProvider在Android系统中访问联系人、短信、图片、音乐和视频等资源,通过具体代码示例展示了如何利用ContentResolver进行数据查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ContentProvider 系统URI

 private  void resolverMethod(){
        ContentResolver contentResolver = getContentResolver();
        Uri uri = ContactsContract.CommonDataKinds.Phone.CONTENT_URI;
        String[] strings={ContactsContract.CommonDataKinds.Phone.NUMBER,ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME};
        Cursor cursor = contentResolver.query(uri, strings, null, null, null);
        while (cursor.moveToNext()){
            String name = cursor.getString(cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME));
            String number = cursor.getString(cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
            Toast.makeText(MainActivity.this, name, Toast.LENGTH_SHORT).show();
            //对象
            Phone phone = new Phone(name, number);
        }
    }



//短信
    private void smsMethod() {
        ContentResolver resolver = getContentResolver();
        Uri uri= Telephony.Sms.CONTENT_URI;
        String[] strs={Telephony.Sms.BODY,Telephony.Sms.ADDRESS};
        Cursor cursor=resolver.query(uri,strs,null,null,null);
        //第一种ListView 中  第二种 :存到数据库
        ArrayList<Msm> list=new ArrayList<>();
        while(cursor.moveToNext()){
            String address=cursor.getString(cursor.getColumnIndex(Telephony.Sms.ADDRESS));
            String body=cursor.getString(cursor.getColumnIndex(Telephony.Sms.BODY));
            Toast.makeText(this, body, Toast.LENGTH_SHORT).show();
            list.add(new Msm(address,body));
            //执行insert语句
        }
    }



//图片
    private void picMethod() {
        //ContentResolver
        ContentResolver contentResolver = getContentResolver();
        //参数一 URI
        //获得图库的URI
        Uri uri1 = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;//图库的URI
        Cursor cursor = contentResolver.query(uri1, null, null, null, null);
        while (cursor.moveToNext()){
            //字段
            String title=cursor.getString(cursor.getColumnIndex(MediaStore.Images.Media.TITLE));
            //图片的地址
            String data=cursor.getString(cursor.getColumnIndex(MediaStore.Images.Media.DATA));
            int height=cursor.getInt(cursor.getColumnIndex(MediaStore.Images.Media.HEIGHT));
            int width=cursor.getInt(cursor.getColumnIndex(MediaStore.Images.Media.WIDTH));
            long size=cursor.getLong(cursor.getColumnIndex(MediaStore.Images.Media.SIZE));
            Log.e("###", "图片: "+title+":"+data+":"+height+":"+width+":"+size);
        }
    }



  //音乐
    private void musicMethod() {
        //ContentResolver
        ContentResolver contentResolver = getContentResolver();
        //参数一 URI
        //获得音乐的URI
        Uri uri1 = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;//音乐的URI
        Cursor cursor = contentResolver.query(uri1, null, null, null, null);
        while (cursor.moveToNext()){
            //字段
            String title=cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.TITLE));
            //地址
            String data=cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.DATA));
            //歌手
            String artist=cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.ARTIST));
            //时长
            long duration=cursor.getLong(cursor.getColumnIndex(MediaStore.Audio.Media.DURATION));
            long size=cursor.getLong(cursor.getColumnIndex(MediaStore.Audio.Media.SIZE));
            Log.i("###", "音乐: "+title+":"+data+":"+artist+":"+duration+":"+size);
        }
    }



 //视频
    private void videoMethod() {
        //ContentResolver
        ContentResolver contentResolver = getContentResolver();
        //参数一 URI
        //获得视频的URI
        Uri uri1 = MediaStore.Video.Media.EXTERNAL_CONTENT_URI;//视频的URI
//        Uri uri1 = Uri.parse("content://media/external/video/media");
        Cursor cursor = contentResolver.query(uri1, null, null, null, null);
        while (cursor.moveToNext()){
            //字段
            String title=cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.TITLE));
            String data=cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.DATA));
            String artist=cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.ARTIST));
            long duration=cursor.getLong(cursor.getColumnIndex(MediaStore.Video.Media.DURATION));
            long size=cursor.getLong(cursor.getColumnIndex(MediaStore.Video.Media.SIZE));
            Log.i("###", "视频: "+title+":"+data+":"+artist+":"+duration+":"+size);
        }
    }



//全部

public class MainActivity extends AppCompatActivity {
        private  Button btn_person;
        private  Button btn_message;
        private  Button btn_image;
        private  Button btn_music;
        private  Button btn_video;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //初始化控件
        btn_person=findViewById(R.id.btn_person);
        btn_message=findViewById(R.id.btn_message);
        btn_image=findViewById(R.id.btn_image);
        btn_music=findViewById(R.id.btn_music);
        btn_video=findViewById(R.id.btn_video);

        //点击事件
        //手机联系人
        btn_person.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //判断是否版本 在6.0以上
                if (Build.VERSION.SDK_INT>=Build.VERSION_CODES.M){
                    requestPermissions(new String[]{Manifest.permission.WRITE_CONTACTS,Manifest.permission.READ_CONTACTS},100);
                }else {
                    resolverMethod();
                }
            }
        });
        //获取短信
        btn_message.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){
                    requestPermissions(new String[]{Manifest.permission.READ_SMS,Manifest.permission.SEND_SMS},101);
                }else{
                    smsMethod();
                }
            }
        });

        //获取图片
        btn_image.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){
                    requestPermissions(new String[]{Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE},102);
                }else{
                    picMethod();
                }
            }
        });
        //获取音乐
        btn_music.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){
                    requestPermissions(new String[]{Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE},103);
                }else{
                    musicMethod();
                }
            }
        });
        //获取视频
        btn_video.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){
                    requestPermissions(new String[]{Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE},104);
                }else{
                    videoMethod();
                }
            }
        });

    }
    //授权回调
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if(requestCode == 100 & grantResults[0] == PackageManager.PERMISSION_GRANTED){
            resolverMethod();
        }else if (requestCode == 101 & grantResults[0] == PackageManager.PERMISSION_GRANTED){
            smsMethod();
        }else if (requestCode == 102 & grantResults[0] == PackageManager.PERMISSION_GRANTED){
            picMethod();
        }else if (requestCode == 103 & grantResults[0] == PackageManager.PERMISSION_GRANTED){
            musicMethod();
        } else if (requestCode == 104 & grantResults[0] == PackageManager.PERMISSION_GRANTED){
            videoMethod();
        }
    }
    //重复使用,封装方法
    private  void resolverMethod(){
        ContentResolver contentResolver = getContentResolver();
        Uri uri = ContactsContract.CommonDataKinds.Phone.CONTENT_URI;
        String[] strings={ContactsContract.CommonDataKinds.Phone.NUMBER,ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME};
        Cursor cursor = contentResolver.query(uri, strings, null, null, null);
        while (cursor.moveToNext()){
            String name = cursor.getString(cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME));
            String number = cursor.getString(cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
            Toast.makeText(MainActivity.this, name, Toast.LENGTH_SHORT).show();
            //对象
            Phone phone = new Phone(name, number);
        }
    }
    //短信
    private void smsMethod() {
        ContentResolver resolver = getContentResolver();
        Uri uri= Telephony.Sms.CONTENT_URI;
        String[] strs={Telephony.Sms.BODY,Telephony.Sms.ADDRESS};
        Cursor cursor=resolver.query(uri,strs,null,null,null);
        //第一种ListView 中  第二种 :存到数据库
        ArrayList<Msm> list=new ArrayList<>();
        while(cursor.moveToNext()){
            String address=cursor.getString(cursor.getColumnIndex(Telephony.Sms.ADDRESS));
            String body=cursor.getString(cursor.getColumnIndex(Telephony.Sms.BODY));
            Toast.makeText(this, body, Toast.LENGTH_SHORT).show();
            list.add(new Msm(address,body));
            //执行insert语句
        }
    }
    //图片
    private void picMethod() {
        //ContentResolver
        ContentResolver contentResolver = getContentResolver();
        //参数一 URI
        //获得图库的URI
        Uri uri1 = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;//图库的URI
        Cursor cursor = contentResolver.query(uri1, null, null, null, null);
        while (cursor.moveToNext()){
            //字段
            String title=cursor.getString(cursor.getColumnIndex(MediaStore.Images.Media.TITLE));
            //图片的地址
            String data=cursor.getString(cursor.getColumnIndex(MediaStore.Images.Media.DATA));
            int height=cursor.getInt(cursor.getColumnIndex(MediaStore.Images.Media.HEIGHT));
            int width=cursor.getInt(cursor.getColumnIndex(MediaStore.Images.Media.WIDTH));
            long size=cursor.getLong(cursor.getColumnIndex(MediaStore.Images.Media.SIZE));
            Log.e("###", "图片: "+title+":"+data+":"+height+":"+width+":"+size);
        }
    }
    //音乐
    private void musicMethod() {
        //ContentResolver
        ContentResolver contentResolver = getContentResolver();
        //参数一 URI
        //获得音乐的URI
        Uri uri1 = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;//音乐的URI
        Cursor cursor = contentResolver.query(uri1, null, null, null, null);
        while (cursor.moveToNext()){
            //字段
            String title=cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.TITLE));
            //地址
            String data=cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.DATA));
            //歌手
            String artist=cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.ARTIST));
            //时长
            long duration=cursor.getLong(cursor.getColumnIndex(MediaStore.Audio.Media.DURATION));
            long size=cursor.getLong(cursor.getColumnIndex(MediaStore.Audio.Media.SIZE));
            Log.i("###", "音乐: "+title+":"+data+":"+artist+":"+duration+":"+size);
        }
    }
    //视频
    private void videoMethod() {
        //ContentResolver
        ContentResolver contentResolver = getContentResolver();
        //参数一 URI
        //获得视频的URI
        Uri uri1 = MediaStore.Video.Media.EXTERNAL_CONTENT_URI;//视频的URI
//        Uri uri1 = Uri.parse("content://media/external/video/media");
        Cursor cursor = contentResolver.query(uri1, null, null, null, null);
        while (cursor.moveToNext()){
            //字段
            String title=cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.TITLE));
            String data=cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.DATA));
            String artist=cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.ARTIST));
            long duration=cursor.getLong(cursor.getColumnIndex(MediaStore.Video.Media.DURATION));
            long size=cursor.getLong(cursor.getColumnIndex(MediaStore.Video.Media.SIZE));
            Log.i("###", "视频: "+title+":"+data+":"+artist+":"+duration+":"+size);
        }
    }
}



//权限
* 获取图库:(读sd卡的权限)
     * (1)uri:MediaStore.Images.Media.EXTERNAL_CONTENT_URI
     * (2)字段:
	MediaStore.Images.Media.TITLE; 图片名称
	MediaStore.Images.Media.SIZE; 大小
	MediaStore.Images.Media.DATA; 地址
	MediaStore.Images.Media.HEIGHT; 高
	MediaStore.Images.Media.WIDTH;* 获取视频:(读sd卡的权限)
     * (1)uri:MediaStore.Video.Media.EXTERNAL_CONTENT_URI
     * (2)字段:TITLE:歌名   ARTIST 歌手   DURATION 总时长  DATA 地址 SIZE 大小
     * String[] strs= new String[]{
	MediaStore.Video.Media.TITLE,		歌名
	MediaStore.Video.Media.ARTIST,	歌手
	MediaStore.Video.Media.DURATION,	总时长
	MediaStore.Video.Media.DATA,		地址
	MediaStore.Audio.Media.SIZE};		大小

*获取音频 : (读sd卡的权限)
     * (1)uri:MediaStore.Audio.Media.EXTERNAL_CONTENT_URI
     * (2)字段:TITLE:歌名   ARTIST 歌手   DURATION 总时长  DATA 地址  SIZE 大小
     * String[] strs= new String[]{
	MediaStore.Audio.Media.TITLE,		歌名
	MediaStore.Audio.Media.ARTIST,	歌手
	MediaStore.Audio.Media.DURATION,	总时长
	MediaStore.Audio.Media.DATA,	地址
	MediaStore.Audio.Media.SIZE};		大小

*获取联系人: (读联系人的权限)
     * (1)uri:ContactsContract.CommonDataKinds.Phone.CONTENT_URI
     * (2)字段:Phone.DISPLAY_NAME 姓名       NUMBER 电话
     * String[] strs= new String[]{
	ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME,		姓名
	ContactsContract.CommonDataKinds.Phone.NUMBER};		电话

*获取短信: (读短信的权限)
     * (1)uri:Telephony.Sms.CONTENT_URI
     * (2)字段:ADDRESS 地址	BODY 内容
     * String[] strs= new String[]{
	Telephony.Sms.ADDRESS,	地址
	Telephony.Sms.BODY};	内容

*通话记录:
     * (1)uri:CallLog.Calls.CONTENT_URI
     * (2)字段:
	NUMBER:电话号码
	DATE:时间 毫秒
	DURATION:总时长 秒
	TYPE 类型


清单文件中:
联网的权限:
	<uses-permission android:name="android.permission.INTERNET"/>

写SD卡权限:
	<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

读SD卡权限:
	<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>

读取联系人的权限:
	<uses-permission android:name="android.permission.READ_CONTACTS"/>

读取短信的权限: 
	<uses-permission android:name="android.permission.READ_SMS"></uses-permission>

读取通话记录的权限:
	<uses-permission android:name="android.permission.READ_CALL_LOG"></uses-permission>

package com.example.tigongzhe; import android.R.integer; 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.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; import android.net.Uri; import android.provider.SyncStateContract.Helpers; import android.text.Selection; import android.util.Log; public class provider extends ContentProvider { private MyOpenHelper myOpenHelper; private SQLiteDatabase sqLiteDatabase; private static final UriMatcher URI_MATCHER=new UriMatcher(UriMatcher.NO_MATCH); private final String TAG="provider"; private static final String authority="com.example.tigongzhe.provider"; static { URI_MATCHER.addURI(authority, "contacter", 1); URI_MATCHER.addURI(authority, "contacter/#", 2); } private static final String _id="id"; private static final String name="name"; private static final String num="num"; @Override public boolean onCreate() { // TODO Auto-generated method stub myOpenHelper=new MyOpenHelper(getContext(), DB_Name, null, version_1); return true; } @Override public String getType(Uri uri) { // TODO Auto-generated method stub int flag=URI_MATCHER.match(uri); switch (flag) { case 2: return "vnd.android.cursor.item/contacter"; case 1: return "vnd.android.dir.item/contacter"; default: throw new IllegalArgumentException("异常参数"); } } @Override public Uri insert(Uri uri, ContentValues values) { // TODO Auto-generated method stub sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: sqLiteDatabase.insert(Table_Name, name, values); break; case 2: long id=sqLiteDatabase.insert(Table_Name, name, values); ContentUris.withAppendedId(uri, id); default: break; } return uri; } @Override public Cursor query(Uri uri, String[] arg1, String arg2, String[] arg3, String arg4) { // TODO Auto-generated method stub Cursor cursor; sqLiteDatabase=myOpenHelper.getReadableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: cursor=sqLiteDatabase.query(Table_Name, arg1, arg2, arg3, null, null,arg4); break; case 2: long id=ContentUris.parseId(uri); arg2=(arg2==null||"".equals(arg2.trim()))? _id+"="+id:arg2+"and"+_id+"="+id; cursor=sqLiteDatabase.query(Table_Name, arg1, arg2, arg3, null, null,arg4); default: throw new IllegalArgumentException("参数错误"); } return cursor; } @Override public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { // TODO Auto-generated method stub int num=0; sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: num=sqLiteDatabase.update(Table_Name, values,selection, selectionArgs); break; case 2: long id=ContentUris.parseId(uri); selection=(selection==null||"".equals(selection.trim()))? _id+"="+id:selection+"and"+_id+"="+id; num=sqLiteDatabase.update(Table_Name, values,selection, selectionArgs); default: break; } return num; } @Override public int delete(Uri uri, String selection, String[] selectionArgs) { // TODO Auto-generated method stub int num=0; sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: num=sqLiteDatabase.delete(Table_Name, selection, selectionArgs); break; case 2: long id=ContentUris.parseId(uri); selection=(selection==null||"".equals(selection.trim()))?_id+"="+id:selection+"and"+_id+"="+id; num=sqLiteDatabase.delete(Table_Name, selection, selectionArgs); default: throw new IllegalArgumentException("异常参数"); } return num; } private final String DB_Name = "mydb.db"; private final String Table_Name="contacter"; private final int version_1=1; private class MyOpenHelper extends SQLiteOpenHelper { public MyOpenHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); } /** * @description 当数据表无连接时创建新的表 */ @Override public void onCreate(SQLiteDatabase db) { String sql = " create table if not exists " + Table_Name + "(id INTEGER PRIMARY KEY AUTOINCREMENT," + "name varchar(64),num varchar(64))"; db.execSQL(sql); } /** * @description 当版本更新时触发的方法 */ @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String sql = " drop table if exists " + Table_Name; db.execSQL(sql); onCreate(db); } } } +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.tigongzhe" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="8" android:targetSdkVersion="18" /> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.example.tigongzhe.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=".provider" android:authorities="com.example.tigongzhe.provider" android:multiprocess="true" android:exported="true" android:permission="com.example.tigongzhe.permission" ></provider> </application> <permission android:name="com.example.tigongzhe.permission" android:protectionLevel="normal"></permission> </manifest> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++package com.example.tigongzhe; import android.R.integer; 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.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; import android.net.Uri; import android.provider.SyncStateContract.Helpers; import android.text.Selection; import android.util.Log; public class provider extends ContentProvider { private MyOpenHelper myOpenHelper; private SQLiteDatabase sqLiteDatabase; private static final UriMatcher URI_MATCHER=new UriMatcher(UriMatcher.NO_MATCH); private final String TAG="provider"; private static final String authority="com.example.tigongzhe.provider"; static { URI_MATCHER.addURI(authority, "contacter", 1); URI_MATCHER.addURI(authority, "contacter/#", 2); } private static final String _id="id"; private static final String name="name"; private static final String num="num"; @Override public boolean onCreate() { // TODO Auto-generated method stub myOpenHelper=new MyOpenHelper(getContext(), DB_Name, null, version_1); return true; } @Override public String getType(Uri uri) { // TODO Auto-generated method stub int flag=URI_MATCHER.match(uri); switch (flag) { case 2: return "vnd.android.cursor.item/contacter"; case 1: return "vnd.android.dir.item/contacter"; default: throw new IllegalArgumentException("异常参数"); } } @Override public Uri insert(Uri uri, ContentValues values) { // TODO Auto-generated method stub sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: sqLiteDatabase.insert(Table_Name, name, values); break; case 2: long id=sqLiteDatabase.insert(Table_Name, name, values); ContentUris.withAppendedId(uri, id); default: break; } return uri; } @Override public Cursor query(Uri uri, String[] arg1, String arg2, String[] arg3, String arg4) { // TODO Auto-generated method stub Cursor cursor; sqLiteDatabase=myOpenHelper.getReadableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: cursor=sqLiteDatabase.query(Table_Name, arg1, arg2, arg3, null, null,arg4); break; case 2: long id=ContentUris.parseId(uri); arg2=(arg2==null||"".equals(arg2.trim()))? _id+"="+id:arg2+"and"+_id+"="+id; cursor=sqLiteDatabase.query(Table_Name, arg1, arg2, arg3, null, null,arg4); default: throw new IllegalArgumentException("参数错误"); } return cursor; } @Override public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { // TODO Auto-generated method stub int num=0; sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: num=sqLiteDatabase.update(Table_Name, values,selection, selectionArgs); break; case 2: long id=ContentUris.parseId(uri); selection=(selection==null||"".equals(selection.trim()))? _id+"="+id:selection+"and"+_id+"="+id; num=sqLiteDatabase.update(Table_Name, values,selection, selectionArgs); default: break; } return num; } @Override public int delete(Uri uri, String selection, String[] selectionArgs) { // TODO Auto-generated method stub int num=0; sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: num=sqLiteDatabase.delete(Table_Name, selection, selectionArgs); break; case 2: long id=ContentUris.parseId(uri); selection=(selection==null||"".equals(selection.trim()))?_id+"="+id:selection+"and"+_id+"="+id; num=sqLiteDatabase.delete(Table_Name, selection, selectionArgs); default: throw new IllegalArgumentException("异常参数"); } return num; } private final String DB_Name = "mydb.db"; private final String Table_Name="contacter"; private final int version_1=1; private class MyOpenHelper extends SQLiteOpenHelper { public MyOpenHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); } /** * @description 当数据表无连接时创建新的表 */ @Override public void onCreate(SQLiteDatabase db) { String sql = " create table if not exists " + Table_Name + "(id INTEGER PRIMARY KEY AUTOINCREMENT," + "name varchar(64),num varchar(64))"; db.execSQL(sql); } /** * @description 当版本更新时触发的方法 */ @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String sql = " drop table if exists " + Table_Name; db.execSQL(sql); onCreate(db); } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值