5

我正在使用ContentProvider添加 mp3 的媒体。

代码是这样的:

// LOOP1_PATH: /mnt/sdcard/60AH/hack043/loop1.mp3

ContentValues values = new ContentValues(5);
values.put(Media.ARTIST, "Android");
values.put(Media.ALBUM, "60AH");
values.put(Media.TITLE, "hack043");
values.put(Media.MIME_TYPE, "audio/mp3");
values.put(Media.DATA, LOOP1_PATH);

getContentResolver().insert(Media.EXTERNAL_CONTENT_URI, values);

如果您运行此代码,它将起作用。如果您尝试运行它两次,您将获得以下堆栈跟踪:

E/Database( 4102): Error inserting album_id=66 title=hack043 title_keyQQQQQ*Q*Q*Q mime_type=audio/mp3 date_added=1342706644 _display_name=loop12.mp3 sort_key=hack043 artist_id=133 _data=/mnt/sdcard/60AH/hack043/loop1.mp3
E/Database( 4102): android.database.sqlite.SQLiteConstraintException: error code 19: constraint failed
E/Database( 4102):  at android.database.sqlite.SQLiteStatement.native_execute(Native Method)
E/Database( 4102):  at android.database.sqlite.SQLiteStatement.execute(SQLiteStatement.java:61)
E/Database( 4102):  at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1582)
E/Database( 4102):  at android.database.sqlite.SQLiteDatabase.insert(SQLiteDatabase.java:1426)
E/Database( 4102):  at com.android.providers.media.MediaProvider.insertInternal(MediaProvider.java:2166)
E/Database( 4102):  at com.android.providers.media.MediaProvider.insert(MediaProvider.java:1984)
E/Database( 4102):  at android.content.ContentProvider$Transport.insert(ContentProvider.java:206)
E/Database( 4102):  at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:146)
E/Database( 4102):  at android.os.Binder.execTransact(Binder.java:320)
E/Database( 4102):  at dalvik.system.NativeStart.run(Native Method)

不是 100% 肯定,但我猜约束失败是因为路径是UNIQUE.

我的问题是:

有没有办法获得有关约束错误的更多信息?

4

1 回答 1

0

不幸的是,这是本机功能的结果。此处列出的代码将转换为错误消息。

于 2012-08-01T20:45:11.720 回答