7

In my app I have a ContentProvider attached to a table in a database with a CursorLoader that fills a ListView in one of my Activities. This table is filled empty by default and gets filled with user input data. I want to allow the user to completely delete all of their stored data and I'm deleting the entire database when this option is selected. The database is then recreated in it's default state when the user starts using the app again, just as it would the first time they used the app.

My issue is when I delete the database, the ContentProvider doesn't detect that the database was deleted and when I go back to my listview activity, the list is still there. I'm also making the app completely reload the ListView Activity instead of just resuming from memory and the list is still there even though the database is empty. The only way I can get the ContentProvider to reload is to kill the app in the system settings and then open it again.

Is there a way to forcefully restart the ContentProvider or to tell it that the data has been updated from outside of the ContentProvider class itself?

wynalazca
  • 106
  • 1
  • 7

3 Answers3

2

You can also simply use the delete method of the content provider without defining a selection:

context.getContentResolver().delete(YourProvider.CONTENT_URI, null, null);
stef
  • 161
  • 1
  • 10
1

I found the solution to my problem here: https://stackoverflow.com/a/8235584/1943155

I was getting my dbHelper in the onCreate of my ContentProvider class just like in the other post and getting a new dbHelper in each method fixed my issue.

Community
  • 1
  • 1
wynalazca
  • 106
  • 1
  • 7
0

You want to populate the listview with a cursorAdapter, and notify the cursor when the content changed in the contentProvider.

In your delete method of your contentProvider implementation, call contentResolver.notify . This will notify the cursor populated by the call to contentResolver that there has been a change in the data.

wangyif2
  • 2,843
  • 2
  • 24
  • 29
  • Yeah, that's what I'm doing. The problem here is the ContentProvider is only attached to one table of my database and a separate Activity that doesn't use the provider deletes the entire database when the user wants to through the getApplicationContext().deleteDatabase(myDb). Is there a way to send a trigger to the provider to restart/refresh it when I don't have direct access to the contentResolver? I'm currently using the delete method in my provider to delete individual rows from the table that's used for my listview/cursoradapter, as you suggest. – wynalazca Apr 20 '13 at 01:13
  • If you are using a loader to load the listview, you can also just call restart on the loader right after you delete your database – wangyif2 Apr 20 '13 at 01:31
  • I was just playing around with it and this didn't fix my issue. Through some more creative searching, I found this issue and the solution worked: http://stackoverflow.com/a/8235584/1943155 – wynalazca Apr 22 '13 at 05:54