Как сохранить и получить изображение из базы данных Sqlite? - PullRequest
0 голосов
/ 28 июня 2011

Я преобразую изображение в данные и сохраняю изображение в базе данных. Подобно следующему NSData * imageData = UIImagePNGRepresentation (imgView.image);

[dataArray addObject:imageData];

И извлекаю данные в изображение следующим образом:

        NSData *imdata = [[tableArray objectAtIndex:indexPath.row] objectForKey:@"Image"];

SQlite Код для сохранения:

   if (sqlite3_open([databasePath UTF8String], &database)== SQLITE_OK)
    {
        NSString *statement;
        sqlite3_stmt *compiledstatement;
        int Id;
        NSString *Name;
        NSData *imgData;



        Id = [[recordArray objectAtIndex:0] intValue];
        Name = [recordArray objectAtIndex:1];

        imgData = [recordArray objectAtIndex:2];
        statement = [[NSString alloc]initWithFormat:@"insert into ImageTable values ('%d','%@','%@')",Id,Name,imgData] ;
        const char *sqlstatement = [statement UTF8String];

        if (sqlite3_prepare_v2(database, sqlstatement, -1, &compiledstatement, NULL)== SQLITE_OK) {
            if (SQLITE_DONE!=sqlite3_step(compiledstatement) ) {
                NSAssert1(0,@"Error when inserting  %s",sqlite3_errmsg(database));
            }
            else {

                NSLog(@"Data inserted Successfully");
            }
            //[recordDict release];
        }
        else {
            NSLog(@"Failed with error");
            NSAssert1(0,@"Error when creation %s",sqlite3_errmsg(database));

        }



    }
    //sqlite3_finalize(compiledstatement);

Sqlite Код для получения:

  - (NSMutableArray *) getRecord
     {
[self checkAndCreateDatabase];

sqlArray=[[NSMutableArray alloc]init ];


if (sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK)
{
    const char *sql = "select * from ImageTable";
    sqlite3_stmt *selectstmt;
    if(sqlite3_prepare_v2(database, sql, -1, &selectstmt, NULL) == SQLITE_OK) 
    {
        while(sqlite3_step(selectstmt) == SQLITE_ROW)
        {
            //[sqlDict retain];
            sqlDict =[[NSMutableDictionary alloc]init ];

            NSString *Id = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 0)];
            //[barcodeArray addObject:prdbcode];
            [sqlDict setObject:Id forKey:@"Id"];
            //[prdbcode release];


            NSString *name = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 1)];
            //[nameArray addObject:prdname];
            [sqlDict setObject:name forKey:@"Name"];
            //[prdname release];


            NSData *image = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 2)];
            //NSData *data = [[NSData alloc] initWithBytes:sqlite3_column_blob(selectstmt, 1) length:sqlite3_column_bytes(selectstmt, 1)];              
            //[descArray addObject:prdDesc];
            [sqlDict setObject:image forKey:@"Image"];
            // [prdDesc release];
            [sqlArray addObject:sqlDict];
        }


        sqlite3_finalize(selectstmt);   

    }

    sqlite3_close(database);
    //  
}

return sqlArray;

}

[imView setImage:[UIImage imageWithData:imdata]];
[cell addSubview:imView];

Идентификатор и имя получены, ноизображение не отображается.приложение завершается без сообщения об ошибке. Пожалуйста, дайте мне знать решение для этого

Ответы [ 2 ]

1 голос
/ 06 июня 2012

Я знаю, что мой ответ слишком поздний, но он может быть полезен для тех, кто просматривает этот вопрос, обычно при записи изображений в таблицу базы данных sqlite с использованием BLOB, что повлияет на производительность базы данных и замедлит работу загрузка данных, когда записи начинают увеличиваться в цифрах. Без использования BLOB вы можете сохранять и извлекать изображения из базы данных, вот post / link , которая поможет вам продолжить и выполнить задачу

Надеюсь, это поможет кому-то, кто поражен хранением изображений в базе данных :)

0 голосов
/ 28 июня 2011

Я не вижу там никакого кода базы данных sqlite.Если вы просто хотите извлечь изображение из вашего массива данных, вам нужно:

NSData *imdata = [dataArray objectAtIndex:indexPath.row];
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...