Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/261.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android-使用字符串使用MediaStore搜索音乐_Android - Fatal编程技术网

Android-使用字符串使用MediaStore搜索音乐

Android-使用字符串使用MediaStore搜索音乐,android,Android,我基本上无法完成这两个多星期了 我已经在几个问题上发布了大量代码,但大多数都被忽略了,所以我不会在这个问题上大量使用我自己的代码,这些代码甚至不会被阅读 如何使用字符串搜索具有“LIKE”属性的MediaStore 例如,我输入shot To thriver,我收到带有以下代码的歌曲ID: if(cursor.moveToFirst()){ while(cursor.moveToNext()){ String

我基本上无法完成这两个多星期了

我已经在几个问题上发布了大量代码,但大多数都被忽略了,所以我不会在这个问题上大量使用我自己的代码,这些代码甚至不会被阅读

如何使用字符串搜索具有“LIKE”属性的MediaStore

例如,我输入shot To thriver,我收到带有以下代码的歌曲ID:

if(cursor.moveToFirst()){
                    while(cursor.moveToNext()){
                        String title = cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.TITLE));
                        String artist = cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.ARTIST));
                        String id = cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media._ID));
                        test.setText(title +" " + artist + " " + id);
                    }
                }
以下是一些开始:

String[] projection = {
                            BaseColumns._ID,    
                            MediaStore.Audio.Artists.ARTIST,
                            MediaStore.Audio.Media.TITLE
                }

Cursor cursor = this.managedQuery(
                        MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, //uri
                        projection, //projection
                        //i dont know what to enter,
                        //i dont know what to enter,
                        MediaStore.Audio.Media.TITLE);

这只是隐藏在幕后的普通SQL。正常的操作应该可以正常工作。您可以像使用任何其他SQL查询一样使用
MediaStore.Audio.Media.TITLE+“LIKE\%thrift%\”

String[] projection = { BaseColumns._ID,
        MediaStore.Audio.Artists.ARTIST, MediaStore.Audio.Media.TITLE };

String where = MediaStore.Audio.Media.TITLE + " LIKE ?";
String[] params = new String[] { "%life%" };

Cursor q = managedQuery(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI,
        projection, where, params, MediaStore.Audio.Media.TITLE);

try {
    while (q.moveToNext()) {
        Log.e("song", q.getString(1) + " " + q.getString(2));
    }
} finally {
    q.close();
}

这是一个非常基本的问题,但我很难解决SQL。。您能告诉我selection和selectionArgs做什么吗?(本例中的where和params)例如,它们如何影响搜索过程?
where
成为SQL查询中的子句
params
用转义值替换WHERE子句中的每个问号,这样您就不必担心引用。你知道我怎么能忽略一些文字吗?假设我必须对歌曲进行排序,并且在排序时忽略单词“the”???