English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Основные уроки SQLite

Умные уроки SQLite

Интерфейс программы SQLite

SQLite C / C ++

В этой главе вы узнаете, как использовать SQLite в программах C / C ++.

Установка

Прежде чем начать использовать SQLite в наших программах C / C ++, вам нужно убедиться, что библиотека SQLite установлена на вашем компьютере. Вы можете ознакомиться с главой «Установка SQLite», чтобы узнать о процессе установки.

API интерфейса C / C ++

Ниже приведены важные примеры интерфейсов 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

До того как продолжить с реальным примером для получения записей, давайте рассмотрим некоторые детали вызова функции обратного вызова, используемого в примере. Вызов функции обратного вызова предоставляет способ получения результатов из 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
Операция успешно завершена

Операция UPDATE

Данный фрагмент 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
Операция выполнена успешно

Операция Delete

Данный фрагмент 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
Операция выполнена успешно