Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.87/15: Рейтинг темы: голосов - 15, средняя оценка - 4.87
 Аватар для MalcolmRed
11 / 11 / 0
Регистрация: 22.09.2012
Сообщений: 56

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

09.11.2013, 17:21. Показов 2878. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 30.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru