Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to copy sqlite database when application is launched in iOS?

I want to copy my sqlite database from the database location with latest updates to my iOS application every time I launch the application.

Is there any way to do it?

like image 281
Toseef Khilji Avatar asked Mar 19 '13 04:03

Toseef Khilji


2 Answers

Here it is in Swift 4/5

    func copyDatabaseIfNeeded(sourcePath : String) -> Bool {
      var destPath = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true).first!
      destPath = destPath + "/foo.db3"
      let databaseExistsWhereNeeded = FileManager.default.fileExists(atPath: destPath)
      if (!databaseExistsWhereNeeded) {
        do {
            try FileManager.default.copyItem(atPath: sourcePath, toPath: destPath)
            print("db copied")
        }
        catch {
            print("error during file copy: \(error)")
        }
    }
    return true
}
like image 76
Jason Avatar answered Oct 01 '22 20:10

Jason


you can add following methods to your appdelegate

- (void) copyDatabaseIfNeeded {

    //Using NSFileManager we can perform many file system operations.
    NSFileManager *fileManager = [NSFileManager defaultManager];
    NSError *error;

    NSString *dbPath = [self getDBPath];
    BOOL success = [fileManager fileExistsAtPath:dbPath];

    if(!success) {

       NSString *defaultDBPath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:@"database.sqlite"];
       success = [fileManager copyItemAtPath:defaultDBPath toPath:dbPath error:&error];

       if (!success)
          NSAssert1(0, @"Failed to create writable database file with message '%@'.", [error localizedDescription]);
    }
}

- (NSString *) getDBPath
{   
    //Search for standard documents using NSSearchPathForDirectoriesInDomains
    //First Param = Searching the documents directory
    //Second Param = Searching the Users directory and not the System
    //Expand any tildes and identify home directories.

    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory , NSUserDomainMask, YES);
    NSString *documentsDir = [paths objectAtIndex:0];
    //NSLog(@"dbpath : %@",documentsDir);
    return [documentsDir stringByAppendingPathComponent:@"database.sqlite"];
}

and call this method in your did finish with launching method [self copyDatabaseIfNeeded]; hope this will help.

like image 32
wasim Avatar answered Oct 01 '22 22:10

wasim