I have a SQlite database file with records which comes with my app.
I just used the file I added to my project to make my INSERT and UPDATE statements.
After uploading it to my test device I got the exception that the file is read only.
After a bit of research I found out, that I have to copy the db file to the users directory to make an insert. This works for now. But I have a view questions about it, which i didn’t get answered through google:
Where should I put my copy process?
I implemented it in the AppDelegates FinishedLaunching, where I check if it already exists.
Where should I copy the file to?
I used the MyDocuments folder for now, is this ok?
Since the file cannot be encrypted, can another app access the database file?
When the user decides to delete the app from the device. Will the database file get deleted,too?
Thanks!
That really depends, but finishedLaunching is OK from my point of view.
I’m not sure what you mean by “MyDocuments” folder. Each Application has a dedicated Document directory. That’s where you should copy it.
No, they run sand-boxed (unless the device is jailbroken)
Yes, since the whole document directory will be deleted.