插入数据库问题

时间:2012-01-26 09:04:36

标签: ios objective-c sqlite

这件事对我来说真的很奇怪我创建一个应用程序,在我的第一个视图(登录视图)我输入电子邮件ID和密码然后从数据库验证这个,如果确定然后移动到新视图并在该视图中我填写一些字段,然后将数据输入数据库,但它将数据输入我的数据库。这是登录视图的验证

-(NSInteger)verifyLoginEmail:(NSString *)email Password:(NSString *)password
{
       NSInteger a=1;
        const char *selectQuery="SELECT * FROM CreateProfile where email=? AND password=?";
        sqlite3_stmt *statement;
        if(sqlite3_open([destPath UTF8String],&studentDB)==SQLITE_OK)
        {
            //sqlite3_bind_int(statement, 1, sid);

            if(sqlite3_prepare_v2(studentDB,selectQuery, -1, &statement, nil)==SQLITE_OK)
            { 
            sqlite3_bind_text(statement, 1, [email UTF8String], -1, SQLITE_TRANSIENT);
            sqlite3_bind_text(statement, 2, [password UTF8String], -1, SQLITE_TRANSIENT);

                if(sqlite3_step(statement)==SQLITE_ROW)
                {

                    return a;
                }
                else 
                {
                    return 2;
                }

            }
                        sqlite3_finalize(statement);
        }
            sqlite3_close(studentDB);


        return 0;
}

此代码用于从新视图插入数据

-(void)insertName:(NSString *)name Email:(NSString *)email Password:(NSString *)password Pic:(NSString *)pic;
{
    const char *insertQuery="insert into CreateProfile (name,email,pic,password) values (?,?,?,?)";
    sqlite3_stmt *statement;
    if(sqlite3_open([destPath UTF8String],&studentDB)==SQLITE_OK)
    {

        if(sqlite3_prepare_v2(studentDB, insertQuery, -1, &statement, nil)==SQLITE_OK)
        { 
            sqlite3_bind_text(statement, 1, [name UTF8String], -1, SQLITE_TRANSIENT);
            sqlite3_bind_text(statement, 2, [email UTF8String], -1, SQLITE_TRANSIENT);
            sqlite3_bind_text(statement, 3, [pic UTF8String], -1, SQLITE_TRANSIENT);  
            sqlite3_bind_text(statement, 4, [password UTF8String], -1, SQLITE_TRANSIENT); 
            //sqlite3_bind_int(statement, 2, rollno);


        }
        if(sqlite3_step(statement)==SQLITE_DONE){
            UIAlertView *alert=[[UIAlertView alloc]initWithTitle:@"Profile Created" message:@"Your profile successfully added" delegate:self cancelButtonTitle:@"Cancel" otherButtonTitles:nil];
            [alert show];
            [alert release];
        }
            sqlite3_finalize(statement);
        }
        sqlite3_close(studentDB);

    }

当我直接从主窗口更改视图进行查看时,我可以在数据库中输入字段但是当我登录然后移动到新视图时我无法进入数据库

1 个答案:

答案 0 :(得分:0)

(NSInteger)verifyLoginEmail:(NSString *)电子邮件密码:(NSString *)密码功能

你写过

   sqlite3_bind_text(statement, 1, [email UTF8String], -1, SQLITE_TRANSIENT);
            sqlite3_bind_text(statement, 2, [password UTF8String], -1, SQLITE_TRANSIENT);

用下面的行替换这两行

   sqlite3_bind_text(statement, 0, [email UTF8String], -1, SQLITE_TRANSIENT);
            sqlite3_bind_text(statement, 1, [password UTF8String], -1, SQLITE_TRANSIENT);

在Select Query中,绑定从0开始。在insert语句中,绑定从1开始。

而不是返回 a ,而是返回一些整数值,例如 1 ,因为您的方法的返回类型是NSInteger。

希望它能奏效。