0
#import "AddEandM.h"
#import "Questions.h"
#import "sqlite3.h"




@interface AddEandM ()

@end


@implementation AddEandM

@synthesize Topic, Question, Answer1, Answer2, Answer3, CorrectAnswer, status;

-(IBAction) backgroundTouched:(id)sender {
    [Topic resignFirstResponder];
    [Question resignFirstResponder];
    [Answer1 resignFirstResponder];
    [Answer2 resignFirstResponder];
    [Answer3 resignFirstResponder];
    [CorrectAnswer resignFirstResponder];


}

-(IBAction) textfieldReturn:(id)sender {
    [sender resignFirstResponder];
}

- (void) saveData
{
    sqlite3 * Questions;
    sqlite3_stmt    *statement;
    const char *dbpath = [databasePath UTF8String];

    if (sqlite3_open(dbpath, &Questions) == SQLITE_OK)

    {

        NSString *insertSQL = [NSString stringWithFormat:

                      @"INSERT INTO DATABASE (Topic, Question, Answer1, Answer2, Answer3, CorrectAnswer) VALUES (\"%@\", \"%@\", \"%@\", \"%@\", \"%@\", \"%@\")",Topic.text, Question.text, Answer1.text, Answer2.text, Answer3.text, CorrectAnswer.text];


    const char *insert_stmt = [insertSQL UTF8String];


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

    if (sqlite3_step(statement) == SQLITE_DONE)

            {
            status.text = @"Question/Answers Added";
                                                    Topic.text = @" ";
                                                    Question.text = @" ";
                                                    Answer1.text = @" ";
                                                    Answer2.text = @" ";
                                                    Answer3.text = @" ";
                                                    CorrectAnswer.text = @" ";

                                        } else {

                        status.text = @"Failed to add Question/Answers";
                                                        }
                                        sqlite3_finalize(statement);
                                        sqlite3_close(Questions);


}
}






-(IBAction)Back:(id)sender {
    Questions *second = [[Questions alloc] initWithNibName:nil bundle:nil];
    [self presentModalViewController:second animated:YES];

}
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
    if (self) {
        // Custom initialization
    }
    return self;
}

- (void)viewDidLoad {
    NSString *docsDir;
    NSArray *dirPaths;

    sqlite3 * Questions;

    dirPaths = NSSearchPathForDirectoriesInDomains(
            NSDocumentDirectory, NSUserDomainMask, YES);

    docsDir = [dirPaths objectAtIndex: 0];

    databasePath = [[NSString alloc]
                    initWithString: [docsDir stringByAppendingPathComponent:
                                     @"Questions"]];
    NSFileManager *filemgr = [NSFileManager defaultManager];

    if ([filemgr fileExistsAtPath:databasePath ] == NO)

    {
        const char *dbpath = [databasePath UTF8String];

        if (sqlite3_open(dbpath, &Questions) == SQLITE_OK)


        {

            char *errMsg;
            const char *sql_stmt = "Create Table If Not Exists Questions (QuestionNo Integer AutoIncrement, Question Text, Answer1 Text, Answer2 Text, Answer 3 Text, Correct Answer Text)";
            if (sqlite3_exec(Questions, sql_stmt, NULL, NULL, &errMsg) != SQLITE_OK)

            status.text = @"Failed to Create Table";
                }

                sqlite3_close(Questions);
                } else {
    status.text  =@"Failed to open/create database";
                }





    [super viewDidLoad];
    // Do any additional setup after loading the view from its nib.
}

- (void)didReceiveMemoryWarning
{
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

    @end

我正在为我的计算机科学课程创建一个修订应用程序,我对 Xcode/Ob C 编程的知识非常有限,谁能帮助我并告诉我这里出了什么问题?我的数据库名为“问题”,包含 2 个表:“EasyandMedium”和“Hard”,但是,我无法让我的程序将数据保存到该数据库 - 请帮助!

4

1 回答 1

1

你到底有什么问题?你知道你的fileExistsAtPath电话是否成功吗?sqlite3_open调用成功了吗?

有很多在 Xcode 中使用 SQLite3 的示例,例如我无法将我的 XCode 项目与我的 SQLite3 数据库链接。我建议检查一下,因为它们是一个很好的起点。

于 2013-02-18T14:28:48.870 回答