Аватар для MalcolmRed
11 / 11 / 0
Регистрация: 22.09.2012
Сообщений: 56

Sqlite3 - выводит ошибку SQLITE_MISUSE

09.11.2013, 17:21. Показов 2886. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Хотел добавить в раздел с БД тему, но там только Билдер а просто С++ БД нету. Переместите если не там создал.

Учу язык С++ и решил написать ООП обертку для работы с БД SQLite3. Когда не использую ООП - все работает хорошо, данные заносятся в базу. Но когда использую классы - выдает ошибку номер 21 - SQLITE_MISUSE. Суть ошибки в том, что я не правильно использую библиотеку. Но как именно не правильно я использую её я не могу понять.

Вот код:

SQL.h:
C++
1
2
3
4
5
6
7
8
9
10
11
 class SQL { public:
    SQL();
    ~SQL();
 
    int openConnect(sqlite3 *pDB, const char db_name[]);
    void closeConnect(sqlite3 *pDB);
    int prepareQuery(sqlite3 *pDB, const char *zSql, int nByte = -1, sqlite3_stmt **ppSTMT = 0, const char
**pzTail = 0);
    int step(sqlite3_stmt *pSTMT);
 
};
SQL.cpp:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int SQL::openConnect(sqlite3 *pDB, const char db_name[]) {
    return sqlite3_open(db_name, &pDB);
}
 
void SQL::closeConnect(sqlite3 *pDB) {
    sqlite3_close(pDB);
}
 
int SQL::prepareQuery(sqlite3 *pDB, const char *zSql, int nByte, sqlite3_stmt **ppSTMT, const char **pzTail) {
    return sqlite3_prepare(pDB, zSql, nByte, ppSTMT, pzTail);
}
 
int SQL::step(sqlite3_stmt *pSTMT) {
    return sqlite3_step(pSTMT);
}
main.cpp:

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
int main()
{
 
    sqlite3 *db;
    int rc;
    char db_name[] = "just_db.sqlite";
    const char *db_query = "insert into `user` values ('hey');";
 
    SQL *sql;
 
    rc = sql->openConnect(db, db_name);
 
    if (rc != SQLITE_OK) {
        std::cout << "Erro: " << sqlite3_errmsg(db);
    }
 
    std::cout << rc << std::endl;
 
    sqlite3_stmt *statement;
 
    rc = sql->prepareQuery(db, db_query, -1, &statement, NULL);
 
    if (rc == SQLITE_OK) {
        std::cout << "Some error: " << sqlite3_errmsg(db);
    }
 
    std::cout << rc << std::endl;
 
    rc = sql->step(statement);
 
    if (rc == SQLITE_ERROR) {
        std::cout << "SOME ERROR: " << sqlite3_errmsg(db);
    }
 
    std::cout << rc << std::endl;
 
    sql->closeConnect(db);
 
  return 0;
}
Результат работы main.cpp:

Code
1
2
3
0
21
21
То есть, подключение к базе выполняется корректно, но дальше выводит ошибки. Возможно я что-то не правильно передаю в методы?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.11.2013, 17:21
Ответы с готовыми решениями:

Выводит ошибку
Type Frac=record{оголошення запису Frac} P:integer; Q:1..32767; var A:array of Drob;{масив векторів} procedure...

Выводит ошибку
Вот код #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;iomanip&gt; #include &lt;cstdlib&gt; using namespace std; int main() { ...

Выводит ошибку
В чем проблема, никак не могу понять #include&lt;iostream&gt; int main() { int year; std::cout&lt;&lt;(&quot;V kakom godu bil osnovan...

10
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
09.11.2013, 18:42
Цитата Сообщение от MalcolmRed Посмотреть сообщение
выдает ошибку номер 21 - SQLITE_MISUSE
Спорим я отгадаю в каком месте выдаёт ошибку!?
1
 Аватар для MalcolmRed
11 / 11 / 0
Регистрация: 22.09.2012
Сообщений: 56
09.11.2013, 19:32  [ТС]
castaway, надеюсь на вашу помощь. Буду рад если укажете мне на ошибку

Строки 24 и 32. Ошибку не выдает по сути. Просто функция возвращает ошибку.
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
09.11.2013, 19:45
Я дал намёк на то, чтобы ты сказал, в каком месте эта ошибка возникает. Но ты же не удосужился нам об этом сообщить..
1
 Аватар для MalcolmRed
11 / 11 / 0
Регистрация: 22.09.2012
Сообщений: 56
09.11.2013, 19:50  [ТС]
castaway, извините. Ошибки возникают в методах prepareQuery() и step(). Эти методы возвращают результат работы sqlite3_prepare() и sqlite3_step() соответственно. 0 - выполнено успешно, 21 - неправильное использование библиотеки. Но я не могу понять как именно я не правильно использую эту библиотеку. Я пробовал искать - но такие проблемы решают функцией sqlite3_finalize(sqlite3_stmt *pStmt). Пробовал использовать её - тоже ничего не меняется.
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
09.11.2013, 19:54
Ты дал код ошибки 21 - SQLITE_MISUSE. Откуда ты его взял? Из какой строки?
1
 Аватар для MalcolmRed
11 / 11 / 0
Регистрация: 22.09.2012
Сообщений: 56
09.11.2013, 19:59  [ТС]
castaway, программа компилируется без ошибок.

C++
1
2
3
if (rc == SQLITE_ERROR) {
        std::cout << "SOME ERROR: " << sqlite3_errmsg(db);
    }
rc - переменная типа int, которая принимает коды ошибок.
Описание ошибок тут: http://www.sqlite.org/c3ref/c_abort.html

Получаю ошибки, которые произошли при вызове функций с помощью sqlite3_errmsg(db). В качестве параметра указатель на БД.
0
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
10.11.2013, 13:29
Цитата Сообщение от MalcolmRed Посмотреть сообщение
int SQL::openConnect(sqlite3 *pDB, const char db_name[]) {
return sqlite3_open(db_name, &pDB);
}
Используйте ссылку на указатель или двойной указатель. Иначе в pDB ничего не возвратится.

Добавлено через 16 часов 58 минут
PS.

Не по теме:

Если уж решили использовать для данной задачи ООП, то имеет смысл внести pDB внутрь класа SQL и инициализировать его в конструкторе. Тогда от концепции ООП получите хоть что-то, кроме лишних строк кода.

1
 Аватар для MalcolmRed
11 / 11 / 0
Регистрация: 22.09.2012
Сообщений: 56
11.11.2013, 18:03  [ТС]
gng, можно пример для понимания? Спасибо.
0
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
11.11.2013, 20:04
Лучший ответ Сообщение было отмечено SatanaXIII как решение

Решение

Цитата Сообщение от MalcolmRed Посмотреть сообщение
gng, можно пример для понимания? Спасибо.
Если вы о указателях, то sqlite3_open принимает двойной указатель и по этому значению записывает возвращаемый указатель на sqlite3.
C++
1
2
3
int SQL::openConnect(sqlite3 *&pDB, const char db_name[]) {
return sqlite3_open(db_name, &pDB);
}
или
C++
1
2
3
int SQL::openConnect(sqlite3 **ppDB, const char db_name[]) {
return sqlite3_open(db_name, ppDB);
}
1
 Аватар для MalcolmRed
11 / 11 / 0
Регистрация: 22.09.2012
Сообщений: 56
12.11.2013, 20:11  [ТС]
gng, спасибо. Никак до конца не могу разобраться с указателями. Тем более с указателями на указатели Первый вариант работает.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.11.2013, 20:11
Помогаю со студенческими работами здесь

Выводит ошибку
В строчке IntToStr(Edit1.Text, a ,c); выводит ошибку в a и c. Что делать? procedure TForm1.Button1Click(Sender: TObject); var ...

Выводит ошибку Next Without For
Подскажите пож. почему первый Next выдает ошибку Next Without For . Пробовала поменять местами next i endif не помогло. Sub zad7() ...

выводит ошибку
в 82 строке #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;iostream&gt; #include &lt;ctime&gt; using namespace std; ...

выводит ошибку, но компилирует
Здравствуйте, скорей всего, я что то напутал с обращением #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; struct root{ ...

PHP выводит ошибку
Вот такая ошибка выводится: Код: Warning: mysqli_query(): Empty query in...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Опции темы

Новые блоги и статьи
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru