Mr_me 2012-09-25 05:53 采纳率: 66.7%
浏览 2386
已采纳

在SQLITE数据库中插入值

在SQLITE数据库中插入值,但是实现不了。代码中的数值都是varchar 类型。
代码如下:

sqlite3_stmt *statement;

NSString *docsDir;
NSArray *dirPaths;
int ID;

dirPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,     
NSUserDomainMask, YES);

docsDir = [dirPaths objectAtIndex:0];

databasePath = [[NSString alloc] initWithString: [docsDir  
stringByAppendingPathComponent: @"weather.sqlite"]];


const char *dbpath = [databasePath UTF8String];

if (sqlite3_open(dbpath, &contactDB) == SQLITE_OK)
{
NSString *insertSQL = [NSString stringWithFormat: @"INSERT INTO satish VALUES    

('jodhpur','hazy1','68','7','700','30','28','10sept')"];

const char *insert_stmt = [insertSQL UTF8String];

sqlite3_prepare_v2(contactDB, insert_stmt, -1, &statement, NULL);
{
    NSLog(@"%@",statement);
    sqlite3_bind_text(statement, 1, insert_stmt, -1, SQLITE_TRANSIENT );

    if (sqlite3_step(statement) == SQLITE_ROW)
    {
        ID = sqlite3_last_insert_rowid(contactDB);

        NSLog(@"Data inserted successfully ");

    } 
    else{             
        NSLog(@"Failed to add contact");
    }
}
sqlite3_finalize(statement);
sqlite3_close(contactDB);
}
  • 写回答

1条回答

  • MrsSeven7 2012-09-25 07:44
    关注
    //试试下面的代码  
    // 需要在数据库里插入列值
    
     NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory , NSUserDomainMask, YES);
        NSString *documentsDir = [paths objectAtIndex:0];
    
        NSFileManager *fileManager = [NSFileManager defaultManager];
        NSError *error;
        NSString *dbPath =[documentsDir stringByAppendingPathComponent:@"register.sqlite"];
        BOOL success = [fileManager fileExistsAtPath:dbPath]; 
        sqlite3_stmt *selectstmt;
        if(!success)
        {
            NSString *defaultDBPath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:@"register.sqlite"];
            success = [fileManager copyItemAtPath:defaultDBPath toPath:dbPath error:&error];
    
            if (!success) 
                NSAssert1(0, @"Failed to create writable database file with message '%@'.", [error localizedDescription]);
        }
    
        if (sqlite3_open([dbPath UTF8String], &database) == SQLITE_OK) {
            //*************** 在数据库中插入值******************************\\ 
    
            const char *sql = "insert into satish (firstname,lastname,email,company,phone) VALUES ('sdcbb','bbbb','bbbb','bbbb',1111122)";
            sqlite3_prepare_v2(database,sql, -1, &selectstmt, NULL); 
            if(sqlite3_step(selectstmt)==SQLITE_DONE)
            {
                NSLog(@"insert successfully");
            }
            else
            {
                NSLog(@"insert not successfully");
    
            }
        sqlite3_finalize(selectstmt);
            sqlite3_close(database);
        }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 iOS 自定义输入法-第三方输入法
  • ¥15 很想要一个很好的答案或提示
  • ¥15 扫描项目中发现AndroidOS.Agent、Android/SmsThief.LI!tr
  • ¥15 怀疑手机被监控,请问怎么解决和防止
  • ¥15 Qt下使用tcp获取数据的详细操作
  • ¥15 idea右下角设置编码是灰色的
  • ¥15 全志H618ROM新增分区
  • ¥15 在grasshopper里DrawViewportWires更改预览后,禁用电池仍然显示
  • ¥15 NAO机器人的录音程序保存问题
  • ¥15 C#读写EXCEL文件,不同编译