1

アプリケーションでユーザーをサインアップしようとしています。ボタン
付きのView Controllerが3 textfields (username, password and confirmpassword)あります。submit

送信ボタンが押されると、次のメソッドが呼び出されます。

-(IBAction)addUser
{
    NSString *tempUser,*tempPass, *tempConfPass;
    tempUser = [[NSString alloc]init];
    tempPass = [[NSString alloc]init];
    tempConfPass = [[NSString alloc]init];
    tempUser = [NSString stringWithFormat:@"%@",_mUserName.text];
    tempPass = [NSString stringWithFormat:@"%@",_mPassword.text];
    tempConfPass = [NSString stringWithFormat:@"%@",_mConfPassword.text];
    signupUser = [[UseDb alloc]init];

    flagUser = [signupUser addNewUser:_mUserName.text:_mPassword.text:_mConfPassword.text];
    if(flagUser)
    {
        myAlertViewUser = [[UIAlertView alloc] initWithTitle:@"Error" message:@"User Added"
                                                    delegate:nil cancelButtonTitle:@"OK" otherButtonTitles: nil];

        [myAlertViewUser show];
    }
    else {
       _mStatus.text = @"failed to add user";
       myAlertViewUser = [[UIAlertView alloc] initWithTitle:@"Error" message:@"passwords don't match"
                                delegate:nil cancelButtonTitle:@"OK" otherButtonTitles: nil];

       [myAlertViewUser show];
    }
}

そして、このメソッドはメソッドによって呼び出されaddUserます:

-(BOOL)addNewUser:(NSString *)newUser :(NSString *)newPassword :(NSString *)confirmPass
{
   NSLog(@"%@....%@...%@",newUser, newPassword, confirmPass);
    sqlite3_stmt    *statement;
    const char *dbpath = [_mDatabasePathDb UTF8String];

    if (sqlite3_open(dbpath, &_mDb) == SQLITE_OK && [newPassword isEqualToString:confirmPass] && ![newUser isEqualToString:@""] && ![newPassword isEqualToString:@""])
    {
        self.userName = [NSString stringWithFormat:@"%@",newUser];
        self.password = [NSString stringWithFormat:@"%@",newPassword];

        NSString *insertSQL = [NSString stringWithFormat:
                               @"INSERT INTO USERDETAIL VALUES (\"%@\",\"%@\",\"%@\", \"%@\",\"%@\", \"%@\",\"%@\", \"%@\",\"%@\", \"%@\",\"%@\")",self.userName,self.password,@"",@"",@"",@"",@"",@"",@"",@"",@"" ];

        NSLog(@"%@",insertSQL);
        const char *insert_stmt = [insertSQL UTF8String];
        sqlite3_prepare_v2(_mDb, insert_stmt, -1, &statement, NULL);

        if (sqlite3_step(statement) == SQLITE_DONE)
        {
            return YES;
            /*    mUserName.text = @"";
             mPassword.text = @"";
             mConfPassword.text = @""; */

        }
        else {

            NSLog(@"failed to add user");
        }

        sqlite3_finalize(statement);
        sqlite3_close(_mDb);
    }
}

addNewUserメソッドでは、 はif (sqlite3_step(statement) == SQLITE_DONE)常に になりfalse、ステートメントの前に何らかの値があります

sqlite3_prepare_v2(_mDb, insert_stmt, -1, &statement, NULL); 

nilしかし、上記のステートメントが実行された後に変わります。なぜそれが起こっているのかわかりません。
助けてください。

4

1 に答える 1

3

これは、実行しているチェックに問題がある可能性があります。SQLITE_OK を試してください。レガシー インターフェイス (古いインターフェイス) では、戻り値はSQLITE_BUSY、SQLITE_DONE、SQLITE_ROW、SQLITE_ERROR、または SQLITE_MISUSE のいずれになります。「v2」インターフェイスでは、他の結果コードまたは拡張結果コードも返される場合があります。

if (sqlite3_prepare_v2(_mDb, insert_stmt, -1, &statement, nil) == SQLITE_OK)
        {
            if (sqlite3_step(statement) == SQLITE_DONE)
            {
               return YES;
            }
            else 
            {
              NSLog(@"failed to add user");
            }
            sqlite3_finalize(statement);
        }

同様の質問とその回答もここで見つけることができます

prepare ステートメントの後に中かっこを挿入し、finalize ステートメントの後で閉じます。SQLITE_MISUSE を取得すると、このルーチンが不適切に呼び出された可能性があります。おそらく、すでにファイナライズされている準備済みステートメント、または以前に SQLITE_ERROR または SQLITE_DONE を返したステートメントで呼び出された可能性があります。または、同じデータベース接続が同時に 2 つ以上のスレッドによって使用されている場合もあります。

お役に立てれば :)

于 2013-06-03T06:58:04.490 に答える