English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
В этой главе вы узнаете, как использовать SQLite в программах C / C ++.
Прежде чем начать использовать SQLite в наших программах C / C ++, вам нужно убедиться, что библиотека SQLite установлена на вашем компьютере. Вы можете ознакомиться с главой «Установка SQLite», чтобы узнать о процессе установки.
Ниже приведены важные примеры интерфейсов C / C ++ SQLite, которые достаточно удовлетворяют требованиям использования базы данных SQLite в программах C / C ++. Если вы ищете более сложные приложения, вы можете обратиться к официальной документации SQLite.
Номер | API и описание |
---|---|
1 | sqlite3_open(const char *filename, sqlite3 **ppDb) Эта процедура открывает соединение с файлом базы данных SQLite и возвращает объект соединения с базой данных, который можно использовать в других процедурах SQLite. ЕслиfilenameЕсли параметр равен NULL или '':memory:'', то sqlite3_open() создаст базу данных в RAM, которая существует только в течение сеанса. Если имя файла не равно NULL, то sqlite3_open() пытается открыть файл базы данных с этим значением. Если файла с таким именем не существует, то sqlite3_open() откроет новый файл базы данных с этим именем. |
2 | sqlite3_exec(sqlite3*, const char *sql, sqlite_callback, void *data, char **errmsg) Этот пример предоставляет быстрый и удобный способ выполнения SQL-запросов, предоставленных параметрами SQL, которые могут состоять из нескольких команд SQL. 在这里,第一个参数sqlite3是一个开放的数据库对象,sqlite_callback是一个回调,其数据是第一个参数,并且将返回errmsg以捕获例程引发的任何错误。 sqlite3_exec()例程解析并执行sql参数中给定的每个命令,直到到达字符串末尾或遇到错误为止。 |
3 | sqlite3_close(sqlite3*) 此例程关闭先前通过调用sqlite3_open()打开的数据库连接。与连接关联的所有准备好的语句应在关闭连接之前完成。 如果还有任何尚未完成的查询,则sqlite3_close()将返回SQLITE_BUSY,错误消息由于未完成的语句而无法关闭。 |
以下C代码段显示了如何连接到现有数据库。如果数据库不存在,则将创建该数据库,最后将返回一个数据库对象。
#include <stdio.h> #include <sqlite3.h> int main(int argc, char* argv[]) { sqlite3 *db; char *zErrMsg = 0; int rc; rc = sqlite3_open("test.db", &db); if( rc ) { fprintf(stderr, "Не удалось открыть базу данных: %s\n", sqlite3_errmsg(db)); возврат(0); } else { fprintf(stderr, "成功打开数据库\n"); } sqlite3_close(db); }
现在,让我们编译并运行上述程序,以test.db在当前目录中创建数据库。您可以根据需要更改路径。
$gcc test.c -l sqlite3 $./a.out 成功打开数据库
如果要使用C ++源代码,则可以按以下方式编译代码-
$g++ test.c -l sqlite3
在这里,我们将程序与sqlite3库链接在一起,以提供C程序所需的功能。这将在您的目录中创建一个数据库文件test.db,您将得到以下结果。
-rwxr-xr-x. 1 root root 7383 May 8 02:06 a.out -rw-r--r--. 1 root root 323 May 8 02:05 test.c -rw-r--r--. 1 root root 0 May 8 02:06 test.db
以下C代码段将用于在先前创建的数据库中创建表-
#include <stdio.h> #include <stdlib.h> #include <sqlite3.h> static int callback(void *NotUsed, int argc, char **argv, char **azColName) { int i; for(i = 0; i<argc; i++) { printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); возврат 0; } int main(int argc, char* argv[]) { sqlite3 *db; char *zErrMsg = 0; int rc; char *sql; /*打开数据库*/ rc = sqlite3_open("test.db", &db); if( rc ) { fprintf(stderr, "Не удалось открыть базу данных: %s\n", sqlite3_errmsg(db)); возврат(0); } else { fprintf(stdout, "已成功打开数据库\n"); } /* Создание SQL-запроса */ sql = "CREATE TABLE COMPANY(" \ "ID INT PRIMARY KEY NOT NULL," \ "NAME TEXT NOT NULL, " \ "AGE INT NOT NULL, " \ "ADDRESS CHAR(50)," \ "SALARY REAL );" /* Выполнение SQL-запроса */ rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); if( rc != SQLITE_OK ) { fprintf(stderr, "Ошибка SQL: %s\n", zErrMsg); sqlite3_free(zErrMsg); } else { fprintf(stdout, "Таблица создана успешно\n"); } sqlite3_close(db); возврат 0; }
После компиляции и выполнения вышеуказанного программы, она создаст таблицу COMPANY в test.db, список файлов в конечном итоге будет следующим-
-rwxr-xr-x. 1 root root 9567 May 8 02:31 a.out -rw-r--r--. 1 root root 1207 May 8 02:31 test.c -rw-r--r--. 1 root root 3072 May 8 02:31 test.db
Следующий фрагмент кода на C показывает, как создать записи в таблице COMPANY, созданной в предыдущем примере-
#include <stdio.h> #include <stdlib.h> #include <sqlite3.h> static int callback(void *NotUsed, int argc, char **argv, char **azColName) { int i; for(i = 0; i<argc; i++) { printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); возврат 0; } int main(int argc, char* argv[]) { sqlite3 *db; char *zErrMsg = 0; int rc; char *sql; /* Открываем базу данных */ rc = sqlite3_open("test.db", &db); if( rc ) { fprintf(stderr, "Не удалось открыть базу данных: %s\n", sqlite3_errmsg(db)); возврат(0); } else { fprintf(stderr, "База данных успешно открыта\n"); } /* Создание SQL-запроса */ sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " \ "VALUES (1, 'Paul', 32, 'California', 20000.00 ); " \ "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " \ "VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); " \ "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " \ "VALUES (3, 'Teddy', 23, 'Norway', 20000.00 ); " \ "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " \ "VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 );" /* Выполнение SQL-запроса */ rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); if( rc != SQLITE_OK ) { fprintf(stderr, "Ошибка SQL: %s\n", zErrMsg); sqlite3_free(zErrMsg); } else { fprintf(stdout, "Успешно создан записи\n"); } sqlite3_close(db); возврат 0; }
После компиляции и выполнения указанного выше программы, она создаст заданную запись в таблице COMPANY и отобразит следующие две строки-
База данных успешно открыта Запись успешно создана
До того как продолжить с реальным примером для получения записей, давайте рассмотрим некоторые детали вызова функции обратного вызова, используемого в примере. Вызов функции обратного вызова предоставляет способ получения результатов из SELECT-запроса. У него есть следующее объявление-
typedef int (*sqlite3_callback)( void* /* Данные, предоставленные в четвертом параметре sqlite3_exec() */ int /* Количество столбцов в строке */ char**, /* Строковая массива полей строки */ char** /* Строковая массива имен столбцов */ );
Если указанный вызов функции обратного вызова предоставлен в процедуре sqlite_exec() в качестве третьего параметра, SQLite вызовет эту функцию обратного вызова для каждой записи, обрабатываемой каждым SELECT-запросом, выполняемым в SQL-параметрах.
Данный фрагмент C-кода показывает, как получить и отобразить записи из таблицы COMPANY, созданной в предыдущем примере-
#include <stdio.h> #include <stdlib.h> #include <sqlite3.h> static int callback(void *data, int argc, char **argv, char **azColName){ int i; fprintf(stderr, "%s: ", (const char*)data); for(i = 0; i<argc; i++){ printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); возврат 0; } int main(int argc, char* argv[]) { sqlite3 *db; char *zErrMsg = 0; int rc; char *sql; const char* data = "Вызвана функция обратного вызова"; /* Открываем базу данных */ rc = sqlite3_open("test.db", &db); if( rc ) { fprintf(stderr, "Не удалось открыть базу данных: %s\n", sqlite3_errmsg(db)); возврат(0); } else { fprintf(stderr, "База данных успешно открыта\n"); } /* Создание SQL-запроса */ sql = "SELECT * from COMPANY"; /* Выполнение SQL-запроса */ rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg); if( rc != SQLITE_OK ) { fprintf(stderr, "Ошибка SQL: %s\n", zErrMsg); sqlite3_free(zErrMsg); } else { fprintf(stdout, "Операция успешно завершена\n"); } sqlite3_close(db); возврат 0; }
После компиляции и выполнения вышеуказанного кода будет получен следующий результат.
База данных успешно открыта Вызвана функция обратного вызова: ИД = 1 ИМЯ = Пол ВОЗРАСТ = 32 АДРЕС = Калифорния ЗАРАБОТНАЯ ПЛАТА = 20000.0 Вызов функции вызова: ID = 2 NAME = Allen ВОЗРАСТ = 25 ADDRESS = Texas SALARY = 15000.0 Вызвана функция обратного вызова: ИД = 3 ИМЯ = Тедди ВОЗРАСТ = 23 АДРЕС = Норвегия ЗАРАБОТНАЯ ПЛАТА = 20000.0 Вызвана функция обратного вызова: ИД = 4 ИМЯ = Марк ВОЗРАСТ = 25 АДРЕС = Rich-Mond ЗАРАБОТНАЯ ПЛАТА = 65000.0 Операция успешно завершена
Данный фрагмент C-кода показывает, как использовать оператор UPDATE для обновления любой записи и затем получить и отобразить обновленные записи из таблицы COMPANY.
#include <stdio.h> #include <stdlib.h> #include <sqlite3.h> static int callback(void *data, int argc, char **argv, char **azColName){ int i; fprintf(stderr, "%s: ", (const char*)data); for(i = 0; i<argc; i++) { printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); возврат 0; } int main(int argc, char* argv[]) { sqlite3 *db; char *zErrMsg = 0; int rc; char *sql; const char* data = "Вызвана функция обратного вызова"; /* Открываем базу данных */ rc = sqlite3_open("test.db", &db); if( rc ) { fprintf(stderr, "Не удалось открыть базу данных: %s\n", sqlite3_errmsg(db)); возврат(0); } else { fprintf(stderr, "База данных успешно открыта\n"); } /* Создание комбинированного SQL-запроса */ sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1;" \ "SELECT * from COMPANY"; /* Выполнение SQL-запроса */ rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg); if( rc != SQLITE_OK ) { fprintf(stderr, "Ошибка SQL: %s\n", zErrMsg); sqlite3_free(zErrMsg); } else { fprintf(stdout, "Операция выполнена успешно\n"); } sqlite3_close(db); возврат 0; }
После компиляции и выполнения вышеуказанного кода будет получен следующий результат.
База данных успешно открыта Вызвана функция обратного вызова: ИД = 1 ИМЯ = Пол ВОЗРАСТ = 32 АДРЕС = Калифорния SALARY = 25000.0 Вызов функции вызова: ID = 2 NAME = Allen ВОЗРАСТ = 25 ADDRESS = Texas SALARY = 15000.0 Вызвана функция обратного вызова: ИД = 3 ИМЯ = Тедди ВОЗРАСТ = 23 АДРЕС = Норвегия ЗАРАБОТНАЯ ПЛАТА = 20000.0 Вызвана функция обратного вызова: ИД = 4 ИМЯ = Марк ВОЗРАСТ = 25 АДРЕС = Rich-Mond ЗАРАБОТНАЯ ПЛАТА = 65000.0 Операция выполнена успешно
Данный фрагмент C-кода показывает, как использовать оператор DELETE для удаления любой записи и затем получить и отобразить оставшиеся записи из таблицы COMPANY.
#include <stdio.h> #include <stdlib.h> #include <sqlite3.h> static int callback(void *data, int argc, char **argv, char **azColName) {}} int i; fprintf(stderr, "%s: ", (const char*)data); for(i = 0; i<argc; i++) { printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); возврат 0; } int main(int argc, char* argv[]) { sqlite3 *db; char *zErrMsg = 0; int rc; char *sql; const char* data = "Вызвана функция обратного вызова"; /* Открываем базу данных */ rc = sqlite3_open("test.db", &db); if( rc ) { fprintf(stderr, "Не удалось открыть базу данных: %s\n", sqlite3_errmsg(db)); возврат(0); } else { fprintf(stderr, "База данных успешно открыта\n"); } /* Создание комбинированного SQL-запроса */ sql = "DELETE from COMPANY where ID=2; \" "SELECT * from COMPANY"; /* Выполнение SQL-запроса */ rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg); if( rc != SQLITE_OK ) { fprintf(stderr, "Ошибка SQL: %s\n", zErrMsg); sqlite3_free(zErrMsg); } else { fprintf(stdout, "Операция выполнена успешно\n"); } sqlite3_close(db); возврат 0; }
После компиляции и выполнения вышеуказанного кода будет получен следующий результат.
База данных успешно открыта Вызвана функция обратного вызова: ИД = 1 ИМЯ = Пол ВОЗРАСТ = 32 АДРЕС = Калифорния ЗАРАБОТНАЯ ПЛАТА = 20000.0 Вызвана функция обратного вызова: ИД = 3 ИМЯ = Тедди ВОЗРАСТ = 23 АДРЕС = Норвегия ЗАРАБОТНАЯ ПЛАТА = 20000.0 Вызвана функция обратного вызова: ИД = 4 ИМЯ = Марк ВОЗРАСТ = 25 АДРЕС = Rich-Mond ЗАРАБОТНАЯ ПЛАТА = 65000.0 Операция выполнена успешно