MediaStore


MediaStore這個類是android系統提供的一個多媒體數據庫,android中多媒體信息都可以從這裏提取。這個MediaStore包括了多媒體數據庫的所有信息,包括音頻,視頻和圖像,android把所有的多媒體數據庫接口進行了封裝,所有的數據庫不用自己進行創建,
直接調用利用ContentResolver去掉用那些封裝好的接口就可以進行數據庫的操作了。今天我就介紹一些這些接口的用法。
      首先,要得到一個ContentResolver實例,ContentResolver可以這樣獲取,利用一個Activity或者Service的Context即可。如下所示:
 
 
ContentResolver mResolver = ctx.getContentResolver();
今天給大家講android的多媒體數據庫。
MediaStore這個類是android系統提供的一個多媒體數據庫,android中多媒體信息都可以從這裏提取。這個MediaStore包括了多媒體數據庫的所有信息,包括音頻,視頻和圖像,android把所有的多媒體數據庫接口進行了封裝,所有的數據庫不用自己進行創建,
直接調用利用ContentResolver去掉用那些封裝好的接口就可以進行數據庫的操作了。今天我就介紹一些這些接口的用法。
      首先,要得到一個ContentResolver實例,ContentResolver可以這樣獲取,利用一個Activity或者Service的Context即可。如下所示:
 
 
ContentResolver mResolver = ctx.getContentResolver();
 
 
上面的那個ctx的就是一個context,Activity.this就是那個Context,這個Context就相當於一個上下文環境。得到這個Context後就可以調用getContentResolver接口獲取ContentResolver實例了。ContentResolver實例獲得後,就可以進行各種查詢,下面我就以音頻數據庫爲例講解增刪改查的方法,視頻和圖像和音頻非常類似。
在講解各種查詢之前,我給大家介紹下怎麼看android都提供了哪些多媒體表。
 
在adb shell中,找到/data/data/com.android.providers.media/databases/下,然後找到SD卡的數據庫文件(一般是一個.db文件),然後輸入命令sqlite3加上這個數據庫的名字就可以查詢android的多媒體數據庫了。.table命令可以列出所有多媒體數據庫的表,.scheme加上表名可以查詢表中的所有列名。這裏可以利用SQL語句來查看你想要的數據,記得最後一定要記住每條語句後面都加上分號。下面開始講述怎麼在這些表上進行增刪改查。
1.查詢,代碼如下所示:
Cursor cursor = resolver.query(_uri, prjs, selections, selectArgs, order);
ContentResolver的query方法接受幾個參數,參數意義如下:
Uri:這個Uri代表要查詢的數據庫名稱加上表的名稱。這個Uri一般都直接從MediaStore裏取得,
例如我要取所有歌的信息,就必須利用MediaStore.Audio.Media. EXTERNAL _CONTENT_URI這個Uri。
          專輯信息要利用MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI這個Uri來查詢.
Prjs:這個參數代表要從表中選擇的列,用一個String數組來表示。
Selections:相當於SQL語句中的where子句,就是代表你的查詢條件。
selectArgs:這個參數是說你的Selections裏有?這個符號是,這裏可以以實際值代替這個問號。如果Selections這個沒有?的話,那麼這個String數組可以爲null。
Order:說明查詢結果按什麼來排序。
上面就是各個參數的意義,它返回的查詢結果一個Cursor,這個Cursor就相當於數據庫查詢的中Result,用法和它差不多。
2.增加,代碼如下所以:
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();
nbsp;   resolver.delete(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,where, selectionArgs);
delete和更新的方法很類似,大家對照更新的方法看下馬上就會明白,今天就寫到這裏了最近比較忙,打算一週發一篇心得體會吧,希望大家也把自己的開發心得寫出來多多交流。


 
 
上面的那個ctx的就是一個context,Activity.this就是那個Context,這個Context就相當於一個上下文環境。得到這個Context後就可以調用getContentResolver接口獲取ContentResolver實例了。ContentResolver實例獲得後,就可以進行各種查詢,下面我就以音頻數據庫爲例講解增刪改查的方法,視頻和圖像和音頻非常類似。
在講解各種查詢之前,我給大家介紹下怎麼看android都提供了哪些多媒體表。
 
在adb shell中,找到/data/data/com.android.providers.media/databases/下,然後找到SD卡的數據庫文件(一般是一個.db文件),然後輸入命令sqlite3加上這個數據庫的名字就可以查詢android的多媒體數據庫了。.table命令可以列出所有多媒體數據庫的表,.scheme加上表名可以查詢表中的所有列名。這裏可以利用SQL語句來查看你想要的數據,記得最後一定要記住每條語句後面都加上分號。下面開始講述怎麼在這些表上進行增刪改查。
1.查詢,代碼如下所示:
Cursor cursor = resolver.query(_uri, prjs, selections, selectArgs, order);
ContentResolver的query方法接受幾個參數,參數意義如下:
Uri:這個Uri代表要查詢的數據庫名稱加上表的名稱。這個Uri一般都直接從MediaStore裏取得,
例如我要取所有歌的信息,就必須利用MediaStore.Audio.Media. EXTERNAL _CONTENT_URI這個Uri。
          專輯信息要利用MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI這個Uri來查詢.
Prjs:這個參數代表要從表中選擇的列,用一個String數組來表示。
Selections:相當於SQL語句中的where子句,就是代表你的查詢條件。
selectArgs:這個參數是說你的Selections裏有?這個符號是,這裏可以以實際值代替這個問號。如果Selections這個沒有?的話,那麼這個String數組可以爲null。
Order:說明查詢結果按什麼來排序。
上面就是各個參數的意義,它返回的查詢結果一個Cursor,這個Cursor就相當於數據庫查詢的中Result,用法和它差不多。
2.增加,代碼如下所以:
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();
nbsp;   resolver.delete(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,where, selectionArgs);
delete和更新的方法很類似,大家對照更新的方法看下馬上就會明白,今天就寫到這裏了最近比較忙,打算一週發一篇心得體會吧,希望大家也把自己的開發心得寫出來多多交流。
MediaStore這個類是android系統提供的一個多媒體數據庫,android中多媒體信息都可以從這裏提取。這個MediaStore包括了多媒體數據庫的所有信息,包括音頻,視頻和圖像,android把所有的多媒體數據庫接口進行了封裝,所有的數據庫不用自己進行創建,
直接調用利用ContentResolver去掉用那些封裝好的接口就可以進行數據庫的操作了。今天我就介紹一些這些接口的用法。
      首先,要得到一個ContentResolver實例,ContentResolver可以這樣獲取,利用一個Activity或者Service的Context即可。如下所示:
 
 
ContentResolver mResolver = ctx.getContentResolver();
 
 
上面的那個ctx的就是一個context,Activity.this就是那個Context,這個Context就相當於一個上下文環境。得到這個Context後就可以調用getContentResolver接口獲取ContentResolver實例了。ContentResolver實例獲得後,就可以進行各種查詢,下面我就以音頻數據庫爲例講解增刪改查的方法,視頻和圖像和音頻非常類似。
在講解各種查詢之前,我給大家介紹下怎麼看andro今天給大家講android的多媒體數據庫。
MediaStore這個類是android系統提供的一個多媒體數據庫,android中多媒體信息都可以從這裏提取。這個MediaStore包括了多媒體數據庫的所有信息,包括音頻,視頻和圖像,android把所有的多媒體數據庫接口進行了封裝,所有的數據庫不用自己進行創建,
直接調用利用ContentResolver去掉用那些封裝好的接口就可以進行數據庫的操作了。今天我就介紹一些這些接口的用法。
      首先,要得到一個ContentResolver實例,ContentResolver可以這樣獲取,利用一個Activity或者Service的Context即可。如下所示:
 
 
ContentResolver mResolver = ctx.getContentResolver();
 
 
上面的那個ctx的就是一個context,Activity.this就是那個Context,這個Context就相當於一個上下文環境。得到這個Context後就可以調用getContentResolver接口獲取ContentResolver實例了。ContentResolver實例獲得後,就可以進行各種查詢,下面我就以音頻數據庫爲例講解增刪改查的方法,視頻和圖像和音頻非常類似。
在講解各種查詢之前,我給大家介紹下怎麼看android都提供了哪些多媒體表。
 
在adb shell中,找到/data/data/com.android.providers.media/databases/下,然後找到SD卡的數據庫文件(一般是一個.db文件),然後輸入命令sqlite3加上這個數據庫的名字就可以查詢android的多媒體數據庫了。.table命令可以列出所有多媒體數據庫的表,.scheme加上表名可以查詢表中的所有列名。這裏可以利用SQL語句來查看你想要的數據,記得最後一定要記住每條語句後面都加上分號。下面開始講述怎麼在這些表上進行增刪改查。
1.查詢,代碼如下所示:
Cursor cursor = resolver.query(_uri, prjs, selections, selectArgs, order);
ContentResolver的query方法接受幾個參數,參數意義如下:
Uri:這個Uri代表要查詢的數據庫名稱加上表的名稱。這個Uri一般都直接從MediaStore裏取得,
例如我要取所有歌的信息,就必須利用MediaStore.Audio.Media. EXTERNAL _CONTENT_URI這個Uri。
          專輯信息要利用MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI這個Uri來查詢.
Prjs:這個參數代表要從表中選擇的列,用一個String數組來表示。
Selections:相當於SQL語句中的where子句,就是代表你的查詢條件。
selectArgs:這個參數是說你的Selections裏有?這個符號是,這裏可以以實際值代替這個問號。如果Selections這個沒有?的話,那麼這個String數組可以爲null。
Order:說明查詢結果按什麼來排序。
上面就是各個參數的意義,它返回的查詢結果一個Cursor,這個Cursor就相當於數據庫查詢的中Result,用法和它差不多。
2.增加,代碼如下所以:
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();
nbsp;   resolver.delete(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,where, selectionArgs);
delete和更新的方法很類似,大家對照更新的方法看下馬上就會明白,今天就寫到這裏了最近比較忙,打算一週發一篇心得體會吧,希望大家也把自己的開發心得寫出來多多交流。id都提供了哪些多媒體表。
 
在adb shell中,找到/data/data/com.android.providers.media/databases/下,然後找到SD卡的數據庫文件(一般是一個.db文件),然後輸入命令sqlite3加上這個數據庫的名字就可以查詢android的多媒體數據庫了。.table命令可以列出所有多媒體數據庫的表,.scheme加上表名可以查詢表中的所有列名。這裏可以利用SQL語句來查看你想要的數據,記得最後一定要記住每條語句後面都加上分號。下面開始講述怎麼在這些表上進行增刪改查。
1.查詢,代碼如下所示:
Cursor cursor = resolver.query(_uri, prjs, selections, selectArgs, order);
ContentResolver的query方法接受幾個參數,參數意義如下:
Uri:這個Uri代表要查詢的數據庫名稱加上表的名稱。這個Uri一般都直接從MediaStore裏取得,
例如我要取所有歌的信息,就必須利用MediaStore.Audio.Media. EXTERNAL _CONTENT_URI這個Uri。
          專輯信息要利用MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI這個Uri來查詢.
Prjs:這個參數代表要從表中選擇的列,用一個String數組來表示。
Selections:相當於SQL語句中的where子句,就是代表你的查詢條件。
selectArgs:這個參數是說你的Selections裏有?這個符號是,這裏可以以實際值代替這個問號。如果Selections這個沒有?的話,那麼這個String數組可以爲null。
Order:說明查詢結果按什麼來排序。
上面就是各個參數的意義,它返回的查詢結果一個Cursor,這個Cursor就相當於數據庫查詢的中Result,用法和它差不多。
2.增加,代碼如下所以:
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();
nbsp;   resolver.delete(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,where, selectionArgs);
delete和更新的方法很類似,大家對照更新的方法看下馬上就會明白,今天就寫到這裏了最近比較忙,打算一週發一篇心得體會吧,希望大家也把自己的開發心得寫出來多多交流。

發佈了3 篇原創文章 · 獲贊 1 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章