首先,要获得一个ContentResolver实例,ContentResolver能够这样获取,利用一个Activity或者Service的Context便可。以下所示: android
ContentResolver mResolver = ctx.getContentResolver(); sql
上面的那个ctx的就是一个context,Activity.this就是那个Context,这个Context就至关于一个上下文环境。获得这个Context后就能够调用getContentResolver接口获取ContentResolver实例了。ContentResolver实例得到后,就能够进行各类查询,下面我就以音频数据库为例讲解增删改查的方法,视频和图像和音频很是相似。 shell
在讲解各类查询以前,我给你们介绍下怎么看android都提供了哪些多媒体表。在adb shell中,找到/data/data/com.android.providers.media/databases/下,而后找到SD卡的数据库文件(通常是一个.db文件),而后输入命令sqlite3加上这个数据库的名字就能够查询android的多媒体数据库了。.table命令能够列出全部多媒体数据库的表,.scheme加上表名能够查询表中的全部列名。这里能够利用SQL语句来查看你想要的数据,记得最后必定要记住每条语句后面都加上分号。下面开始讲述怎么在这些表上进行增删改查。 数据库
查询,代码以下所示: 数组
Cursor cursor = resolver.query(_uri, prjs, selections, selectArgs, order); ide
ContentResolver的query方法接受几个参数,参数意义以下: this
Uri:这个Uri表明要查询的数据库名称加上表的名称。这个Uri通常都直接从MediaStore里取得,例如我要取全部歌的信息,就必须利用MediaStore.Audio.Media. EXTERNAL _CONTENT_URI这个Uri。专辑信息要利用MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI这个Uri来查询,其余查询也都相似。 google
Prjs:这个参数表明要从表中选择的列,用一个String数组来表示。 视频
Selections:至关于SQL语句中的where子句,就是表明你的查询条件。 sqlite
selectArgs:这个参数是说你的Selections里有?这个符号是,这里能够以实际值代替这个问号。若是Selections这个没有?的话,那么这个String数组能够为null。
Order:说明查询结果按什么来排序。
上面就是各个参数的意义,它返回的查询结果一个Cursor,这个Cursor就至关于数据库查询的中Result,用法和它差很少。
增长,代码以下因此:
ContentValues values = new ContentValues();
values.put(MediaStore.Audio.Playlists.Members.PLAY_ORDER,0);
resolver.insert(_uri, values);
这个insert传递的参数只有两个,一个是Uri(同查询那个Uri),另外一个是ContentValues。这个ContentValuses对应于数据库的一行数据,只要用put方法把每一个列的设置好以后,直接利用insert方法去插入就行了。
更新,代码以下:
ContentResolver resolver = ctx.getContentResolver();
Uri uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
ContentValues values = new ContentValues();
values.put(MediaStore.Audio.Media.DATE_MODIFIED, sid);
resolver.update(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,values, where, selectionArgs);
上面update方法和查询还有增长里的参数都很相似,这里就再也不重复叙述了,你们也可直接参考google的文档,那里也写的很清楚。
删除,代码以下:
ContentResolver resolver = ctx.getContentResolver();
resolver.delete(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,where, selectionArgs);
delete和更新的方法很相似,你们对照更新的方法看下立刻就会明白,今天就写到这里了最近比较忙,打算一周发一篇心得体会吧,但愿你们也把本身的开发心得写出来多多交流。