首页 > 解决方案 > 电视提供商 Delete 不适用于 where 子句

问题描述

我正在尝试通过 JobService asynctaks 删除我的应用在 TV.db 中插入的一些频道。

每次我在删除时遇到安全异常。

Process: com.app, PID: 7026
    java.lang.RuntimeException: An error occured while executing doInBackground()
        at android.os.AsyncTask$3.done(AsyncTask.java:304)
        at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
        at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
        at java.util.concurrent.FutureTask.run(FutureTask.java:242)
        at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
        at java.lang.Thread.run(Thread.java:818)
     Caused by: java.lang.SecurityException: Selection not allowed for content://android.media.tv/channel?input=<My package>%2F.live.TvInputService&browsable_only=false
        at android.os.Parcel.readException(Parcel.java:1574)
        at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:185)
        at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:137)
        at android.content.ContentProviderProxy.delete(ContentProviderNative.java:544)
        at android.content.ContentResolver.delete(ContentResolver.java:1299)
        at com.TvContractUtills.updateChannelsWithGraceNote(TvContractUtills.java:173)
        at com.EpgUpdateTask.doInBackground(EpgUpdateTask.java:48)
        at com.EpgUpdateTask.doInBackground(EpgUpdateTask.java:11)
        at android.os.AsyncTask$2.call(AsyncTask.java:292)
        at java.util.concurrent.FutureTask.run(FutureTask.java:237)
        at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
        at java.lang.Thread.run(Thread.java:818) 

这行代码导致上述错误

resolver.delete(channelsUri,TvContract.Channels._ID+ " in ("+getListOfIds(availableChannelMap) +" )" , null);

availableChannelMap 返回以逗号分隔的频道 ID 列表。

当我将 where 子句保持为空时,相同的代码有效。

  resolver.delete(channelsUri,null , null);

知道为什么会这样。

标签: javaandroidsqlitejobservice

解决方案


要删除频道,您需要ContentResolver像这样调用

context.contentResolver.delete(TvContractCompat.buildChannelUri(channelId), null, null)

如果要删除多个频道,请将其放入循环中。我不确定这是否是正确的方法。我在providersAPI 中看不到任何可用的批量删除方法。它虽然有效。


推荐阅读