使用xcode4.6中的sqlite将图像插入到数据库中

Sam*_*ior 5 database sqlite image ios

即时工作在Xcode 4.6中使用sqlite 将IMAGE插入数据库,我只想插入一个textfielduiimageview(具有动态生成的条形码图像).

不幸的是我得到"错误是:内存不足"

听到我正在使用的代码,请告诉我我的错误在哪里并告诉我更多细节

*1.数据库创建*

-(void)createoropendb {

    NSArray *path =NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString *docpath =[path objectAtIndex:0];

    dbpathstring =[docpath stringByAppendingPathComponent:@"DataBase.db"];
    char *error;

    NSFileManager *filemanager =[NSFileManager defaultManager];

    if (![filemanager fileExistsAtPath:dbpathstring])
    {
        const char *dbpath =[dbpathstring UTF8String];

        if (sqlite3_open(dbpath, &barcodeDB) == SQLITE_OK)
        {
            const char *sql_start ="CREATE TABLE IF NOT EXISTS DBTABLE1(NAME TEXT UNIQUE,IMAGEURL BLOB)";
             NSLog(@"db created");
            sqlite3_exec(barcodeDB, sql_start,NULL,NULL, &error);
            sqlite3_close(barcodeDB);

        }
    }
}
Run Code Online (Sandbox Code Playgroud)

*2.按钮插入数据*

- (IBAction)savedata:(id)sender  {
    UIImage *image =imageView.image;
    NSData *imageData=UIImagePNGRepresentation(image);   
    [self SaveImagesToSql: imageData.bytes:Uimagetext.text];  
}
Run Code Online (Sandbox Code Playgroud)

*3.插入数据的方法*

- (void) SaveImagesToSql: (NSData*) imgData :(NSString*) mainUrl {   

    const char* sqliteQuery = "INSERT INTO DBTABLE1(NAME,IMAGEURL) VALUES (?, ?)";
    sqlite3_stmt* statement;

    if( sqlite3_prepare_v2(barcodeDB, sqliteQuery, -1, &statement, NULL) == SQLITE_OK )
    {
        sqlite3_bind_text(statement, 1,[mainUrl UTF8String], -1, SQLITE_TRANSIENT);
        sqlite3_bind_blob(statement, 2,[imgData bytes],[imgData length], SQLITE_TRANSIENT);

        sqlite3_step(statement);

        NSLog( @"Saved image successfully" );

    }
    else
    {


      NSLog( @"SaveBody: Failed from sqlite3_prepare_v2. Error is:  %s",sqlite3_errmsg(barcodeDB) );
    }
    // Finalize and close database.
    sqlite3_finalize(statement);
}
Run Code Online (Sandbox Code Playgroud)

Rob*_*Rob 1

返回代码(不是SQLITE_OK)无疑是 returns SQLITE_MISUSE,这意味着您正在尝试使用尚未打开的数据库。如果数据库不存在,则您createoropendb正在创建并打开它,但如果它确实存在,您就不会打开它(即使它确实存在,您也会在创建后关闭它)。

最重要的是,如果您调用 时数据库未打开sqlite3_prepare,该函数将返回SQLITE_MISUSE,任何调用都sqlite3_errmsg将返回误导性的“内存不足”文本消息。