Форум программистов, компьютерный форум CyberForum.ru

Программирование iOS/iPhone

Войти
Регистрация
Восстановить пароль
 
Noobass
0 / 0 / 0
Регистрация: 15.10.2012
Сообщений: 100
#1

Не получается открыть Базу Данных - Программирование iOS

29.05.2013, 16:55. Просмотров 662. Ответов 6
Метки нет (Все метки)

Всем привет, форумчане! Я тут недавно задавал вопрос о том, как подключить базу данных к приложению. Завалили вы меня инфой по самые помидоры, и я, конечно, все варианты еще не испробовал (ибо многие пути требуют большой реконструкции логики приложения, а мне это не нравится, так как я чайник еще). Но, я тут покумекал и понял некоторые свои ошибки. Я написал функцию инициализации базы данных, которая подключает базу к приложению, ну а если ее нет, то она "вытягивает ее из ресурсника. Вот код:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
-(void) initDataBase
{
 NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
 NSString *documentsDirectory = [paths objectAtIndex:0];
 NSString *databasePath = [documentsDirectory stringByAppendingPathComponent:@"FOOTBALL"];
 
 dataBaseFullPath = databasePath;
 
 // Check to see if the database file already exists
 bool databaseAlreadyExists = [[NSFileManager defaultManager] fileExistsAtPath:databasePath];
 
    databaseAlreadyExists = [[NSFileManager defaultManager] fileExistsAtPath:databasePath];
    if (!databaseAlreadyExists)
    {
        NSArray *pathsDB = NSSearchPathForDirectoriesInDomains( NSDocumentDirectory, NSUserDomainMask, YES);
        NSString* documentsDir = [pathsDB objectAtIndex:0];
        
        NSString *storePath = [documentsDir stringByAppendingPathComponent: @"FOOTBALL.sqlite"];
        
        NSFileManager *fileManager = [NSFileManager defaultManager];
        
        if (![fileManager fileExistsAtPath:storePath])
        {
            
            NSString *defaultStorePath = [[NSBundle mainBundle] pathForResource:@"FOOTBALL" ofType:@"sqlite3"];
            if (defaultStorePath) {
                [fileManager copyItemAtPath:defaultStorePath toPath:storePath error:NULL];
            }
        }
    }
    
}
Проблема в том, что функция не может достучаться до базы и идет во внутренний блок
C#
1
2
if (!databaseAlreadyExists)
    {
где тоже не может ее найти В итоге - FAIL.

Так вот, я думаю, что может я просто неправильно подключаю базу? Может неверно формирую свой запрос? В чем именно моя ошибка?

З.Ы.: Да, я знаю - есть CoreData и все такое, но опять же - я потратил немного времени на изучение этого фрэймворка, там немного своя логика, что требует начать все с нуля. Ну а мне так все до конца довести хочется Очень надеюсь на вашу помощь, отзывчивые форумчане
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Pro2005
44 / 44 / 3
Регистрация: 27.05.2013
Сообщений: 163
29.05.2013, 17:07     Не получается открыть Базу Данных #2
Ты упускаешь расширение файла
C#
1
NSString *databasePath = [documentsDirectory stringByAppendingPathComponent:@"FOOTBALL"];
Вот более правильный код:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
-(void) initDataBase
{
    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString *documentsDirectory = [paths objectAtIndex:0];
    NSString *dbFileName = @"FOOTBALL.sqlite3";
    NSString *databasePath = [documentsDirectory stringByAppendingPathComponent:dbFileName];
    
    dataBaseFullPath = databasePath;
    // Check to see if the database file already exists
    bool databaseAlreadyExists = [[NSFileManager defaultManager] fileExistsAtPath:databasePath];
    
    databaseAlreadyExists = [[NSFileManager defaultManager] fileExistsAtPath:databasePath];
    if (!databaseAlreadyExists)
    {
        NSArray *pathsDB = NSSearchPathForDirectoriesInDomains( NSDocumentDirectory, NSUserDomainMask, YES);
        NSString* documentsDir = [pathsDB objectAtIndex:0];
        
        NSString *storePath = [documentsDir stringByAppendingPathComponent:dbFileName];
        
        NSFileManager *fileManager = [NSFileManager defaultManager];
        
        if (![fileManager fileExistsAtPath:storePath])
        {
            
            NSString *defaultStorePath = [[NSBundle mainBundle] pathForResource:[dbFileName stringByDeletingPathExtension] ofType:[dbFileName pathExtension]];
            if (defaultStorePath) {
                [fileManager copyItemAtPath:defaultStorePath toPath:storePath error:NULL];
            }
        }
    }
    
}
Добавлено через 1 минуту
В одном месте :
C#
1
NSString *databasePath = [documentsDirectory stringByAppendingPathComponent:@"FOOTBALL"];
В другом :
C#
1
NSString *storePath = [documentsDir stringByAppendingPathComponent: @"FOOTBALL.sqlite"];
Ну и еще вот так :
C#
1
NSString *defaultStorePath = [[NSBundle mainBundle] pathForResource:@"FOOTBALL" ofType:@"sqlite3"];
Ты уж определись с расширением....
Noobass
0 / 0 / 0
Регистрация: 15.10.2012
Сообщений: 100
29.05.2013, 17:11  [ТС]     Не получается открыть Базу Данных #3
Pro2005, все равно не работает (( Когда ставлю брекпоинт, вижу, что прога заходит в блок "если база не найдена", и потом пропускает блок "если база открыта". Блин, я уже столько времени парюсь с этой БД, что уж очень хочется ругаться
Pro2005
44 / 44 / 3
Регистрация: 27.05.2013
Сообщений: 163
29.05.2013, 17:14     Не получается открыть Базу Данных #4
Я не могу понять что ты ожидаешь от этого метода...
Этот метод проверяет если в Documents документ FOOTBALL.sqlite3... если нет он его копирует из Bundle - вот и все... Т.е при самом первом запуске на девайсе, будет выполнен этот if
C#
1
if (!databaseAlreadyExists)
При последующих - уже не будет, т.к в папке Documents уже будет файл FOOTBALL.sqlite3
Noobass
0 / 0 / 0
Регистрация: 15.10.2012
Сообщений: 100
29.05.2013, 17:15  [ТС]     Не получается открыть Базу Данных #5
Pro2005, Хорошо, тогда как мне сделать так, чтобы связать базу данных с приложением?
Видимо, простой функции sqlite3_open для этого недостаточно ((
Pro2005
44 / 44 / 3
Регистрация: 27.05.2013
Сообщений: 163
29.05.2013, 17:21     Не получается открыть Базу Данных #6
sqlite3_open - ты должен передать полный путь к БД
если работаешь внутри Bundle - то в БД нельзя вносить изменения (read-only)
если скопируешь БД в Documents - то туда можно еще и делать записи....
Пройдись по своему коду... там где ты выполняешь sqlite3_open - и посмотри правильный ли путь к БД ты передаешь... Воспользуйся NSLog, чтобы вывести нужные переменные в консоль...

Добавлено через 1 минуту
Или дай более полный листинг кода... что дальше твориться после вызова метода initDataBase....
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.05.2013, 18:39     Не получается открыть Базу Данных
Еще ссылки по теме:
Visual Basic .NET Открыть базу данных с паролем
Не удалось открыть базу данных C# ASP.NET .NET 3.x
Не получается подключить базу данных C#
Открыть базу данных с расширением .dat
Delphi БД SQLite Как открыть базу данных sqlite 3.x?

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Noobass
0 / 0 / 0
Регистрация: 15.10.2012
Сообщений: 100
29.05.2013, 18:39  [ТС]     Не получается открыть Базу Данных #7
Pro2005,

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
@implementation DataController
 
@synthesize answers = _answers;
 
-(void) initDataBase
{
    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString *documentsDirectory = [paths objectAtIndex:0];
    NSString *dbFileName = @"FOOTBALL.sqlite3";
    NSString *databasePath = [documentsDirectory stringByAppendingPathComponent:dbFileName];
    
    dataBaseFullPath = databasePath;
    // Check to see if the database file already exists
    bool databaseAlreadyExists = [[NSFileManager defaultManager] fileExistsAtPath:databasePath];
    
    databaseAlreadyExists = [[NSFileManager defaultManager] fileExistsAtPath:databasePath];
    if (!databaseAlreadyExists)
    {
        NSArray *pathsDB = NSSearchPathForDirectoriesInDomains( NSDocumentDirectory, NSUserDomainMask, YES);
        NSString* documentsDir = [pathsDB objectAtIndex:0];
        
        NSString *storePath = [documentsDir stringByAppendingPathComponent:dbFileName];
        
        NSFileManager *fileManager = [NSFileManager defaultManager];
        
        if (![fileManager fileExistsAtPath:storePath])
        {
            
            NSString *defaultStorePath = [[NSBundle mainBundle] pathForResource:@"FOOTBALL" ofType:@"sqlite3"];
            if (defaultStorePath) {
                [fileManager copyItemAtPath:defaultStorePath toPath:storePath error:NULL];
            }
        }
    }
    
}
 
-(NSMutableArray*) getQuestion
{
    NSMutableArray *questionsArray = nil;
    sqlite3_stmt* question;
    char *error = NULL;
    NSString* questionGet;
    DataController *dataController = [[DataController alloc] init];
    [dataController initDataBase];
    
    if (sqlite3_open([dataBaseFullPath UTF8String], &_myBase) == SQLITE_OK) {
        questionGet = [NSString stringWithFormat:@"SELECT Questions FROM QuestionsAndAnswers"];
        if (sqlite3_prepare_v2(_myBase, [questionGet UTF8String], -1, &question, NULL ) == SQLITE_OK)
        {
            questionsArray = [[NSMutableArray alloc] init];
            // NSLog(@"Setup row inserted %i" ,cnt);
            while(sqlite3_step(question) == SQLITE_ROW)
            {
                [questionsArray addObject:[NSString stringWithUTF8String:(char*)sqlite3_column_text(question, 0)]];
            }
            
        }
        else
        {
            NSLog(@"Error: %s", error);
            NSLog(@"SQL: %s", [questionGet UTF8String]);
        }
        sqlite3_finalize(question);
        sqlite3_close(_myBase);
    }
    else
    {
        NSLog(@"Database failed to open.");
    }
    //    return [questionsArray autorelease];
    return questionsArray;
}
 
-(NSMutableArray*) getAnswer: (int) number
{
    NSString* ans;
    if(number == 1)
    {
        ans = [NSString stringWithFormat:@"A"];
    }
    else if(number == 2)
    {
        ans = [NSString stringWithFormat:@"B"];
    }
    else if(number == 3)
    {
        ans = [NSString stringWithFormat:@"C"];
    }
    else if(number == 4)
    {
        ans = [NSString stringWithFormat:@"D"];
    }
    sqlite3_stmt* answer;
    char *error;
    NSString* answerGet;
    NSMutableArray* answerArray;
    answerGet = [NSString stringWithFormat:@"SELECT answer %@ FROM QuestionsAndAnswers", ans];
    if(sqlite3_prepare_v2(_myBase, [answerGet UTF8String], -1, &answer, NULL) == SQLITE_OK)
    {
        while(sqlite3_step(answer) == SQLITE_ROW)
        {
            [answerArray addObject:[NSString stringWithUTF8String:(char*)sqlite3_column_text(answer, number)]];
        }
    }
    else
    {
        NSLog(@"Error: %s", error);
        NSLog(@"SOL: %s", [answerGet UTF8String]);
    }
    return answerArray;
}
 
@end
Добавлено через 1 час 14 минут
Pro2005, все, уже открыл, получилось
Yandex
Объявления
29.05.2013, 18:39     Не получается открыть Базу Данных
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru