Do tej pory udało mi się stworzyć tę metodę do wstawiania do bazy danych SQLite na iPhone:Wkładanie NSData do SQLite na iPhone
- (void) insertToDB :(NSString *)Identifier :(NSString *)Name
{
sqlite3 *database;
if(sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK)
{
char *sql1 = "INSERT INTO table VALUES ('";
const char *sql2 = [Identifier cStringUsingEncoding:[NSString defaultCStringEncoding]];
char *sql3 = "', '";
const char *sql4 = [Name cStringUsingEncoding:[NSString defaultCStringEncoding]];
char *sql5 = "')";
char *sqlStatement[255];
strcpy(sqlStatement, sql1);
strcat(sqlStatement, sql2);
strcat(sqlStatement, sql3);
strcat(sqlStatement, sql4);
strcat(sqlStatement, sql5);
sqlite3_stmt *compiledStatement;
if(sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK)
{
sqlite3_last_insert_rowid(database);
sqlite3_reset(compiledStatement);
}
sqlite3_finalize(compiledStatment);
}
sqlite3_close(database);
}
Teraz patrzę na przechowywanie obrazu w bazie danych. Do tej pory mam found this:
UIImage *cachedImage = [UIImage imageNamed:@"Icon.png"];
NSData *dataForImage = UIImagePNGRepresentation(cachedImage);
ale mam kłopoty próbuje wstawić ten NSData do tablicy char, która sprawia, że SQLStatement. Czy ktoś ma pomysł, jak to zrobić?
(Mam pole w bazie danych typu blob dla tego).
Dzięki
Do * not * put BLOBs w bazie danych. Jest okropnie nieefektywny na wszystkich poziomach. Zapisz ścieżkę w bazie danych i umieść obiekt BLOB w systemie plików. – bbum
Chciałbym * bardzo * polecić korzystanie z opakowania bazy danych Flying Meat, które rozwiązało już wszystkie te problemy i jest * znacznie * prostsze w użyciu: http://github.com/ccgus/fmdb –