OpenSCADAWiki: Doc/SQ Lite ...

Home | Index | Changes | Comments | Users | Registration | Login  Password:  
 
This is an old revision of Doc/SQLite from 2016-07-03 19:14:25..


Модуль подсистемы “БД” <SQLite>


Модуль:SQLite
Имя:БД SQLite
Тип:БД
Источник:bd_SQLite.so
Версия:2.1.0
Автор:Роман Савоченко
Описание:Модуль БД. Предоставляет поддержку БД SQLite.
Лицензия:GPL

Contents

Введение

Модуль <SQLite> предоставляет в систему OpenSCADA поддержку БД SQLite. БД SQLite является небольшой, встраиваемой БД поддерживающей SQL-запросы. БД SQLite распространяется по свободной лицензии. Ознакомиться с БД можно на сайте БД — http://sqlite.org. Модуль основан на библиотеке C/ API производителя БД. Модуль позволяет выполнять действия над базами данных, таблицами и содержимым таблиц.

1. Операции над БД

Поддерживаются операции открытия и закрытия БД, с возможностью создания новой БД при открытии и удаления существующей при закрытии. В терминах подсистемы «БД», системы OpenSCADA, открытием БД является её регистрация для последующего использования в системе. Также, поддерживается операция запроса перечня таблиц в БД.


БД SQLite адресуется путём указания имени файла БД в формате: [<FileDBPath>]. Где:


Модуль поддерживает кодирование данных в нужную кодировку. С этой целью, для БД в целом, можно указать рабочую кодировку. В процессе работы будет выполняться кодирование данных, базы данных, из кодировки БД в системную кодировку OpenSCADA и обратно.

2. Операции над таблицей

Поддерживаются операции открытия, закрытия таблицы, с возможностью создания новой таблицы при открытии и удаления существующей при закрытии, а также запрос структуры таблицы.

3. Операции над содержимым таблицы


API подсистемы “БД” предполагает доступ к содержимому таблицы по значению ключевого(ых) полей. Так, операция запроса записи подразумевает предварительную установку ключевых колонок объекта TConfig, по которым будет выполнен запрос. Создание новой записи(строки) производится операцией установки значений записи, которая отсутствует.


Модуль позволяет динамически менять структуру таблиц БД SQLite, путём создания новой БД с требуемой структурой и копирование в неё данных из старой. Так, в случае несоответствия структуры таблицы и структуры устанавливаемой записи, структура таблицы будет приведена к требуемой структуре записи. В случае запроса значений записи и не соответствия структур записи и таблицы, будут получены только значения общих элементов записи и таблицы. Модуль не отслеживает порядка расположения элементов записи и структуры таблицы!


Модулем реализуется механизм поддержки многоязыковых текстовых переменных. Для полей с многоязыковой текстовой переменной создаются колонки отдельных языков в формате <lang>#<FldID> (en#NAME). При этом базовая колонка содержит значение для базового языка. Колонки отдельных языков создаются по надобности, в момент сохранения в БД и при исполнении OpenSCADA в соответствующей локали. В случае отсутствия значения для конкретного языка будет использоваться значений для базового языка.


Типы элементов БД SQLite следующим образом соответствуют типам элементов системы OpenSCADA:

Типы полей системы OpenSCADAТипы полей БД SQLite
TFld::StringTEXT
TFld::Integer, TFld::BooleanINTEGER
TFld::RealDOUBLE

4. Права доступа

Права доступа к БД определяются правами доступа к отдельно взятому файлу БД. Модулем поддерживается работа с файлами БД SQLite в режиме только для чтения, например в демонстрациях.

5. Производительность БД

Замер производительности БД выполнялся тестом «БД», модуля системных тестов "SystemTests", путём выполнения операций над записями структурой: <name char (20), descr char (50), val double (10.2), id int (7), stat bool, reqKey string, reqVal string>.

Операция Nokia N800, SD 2G AMD Turion L625 1.6, 2G, SQLite [3.7.6.2; 3.7.13] Intel(R) Core(TM) i3 CPU 1.33GHz, 3G, HDD, SQLite 3.7.13
Создание 1000 записей (сек.): 6.3 0.39; 0.49 0.393
Обновление 1000 записей (сек.): 6.3 0.43; 0.48 0.403
Получение 1000 записей (сек.): 4.5 0.31; 0.36 0.307
Сканирование 1000 записей (сек.): - - 0.214
Удаление 1000 записей (сек.): 2.5 0.1; 0.08 0.067

Ссылки

Referring pages: Doc
Doc/OpenSCADA060
Function
Using/PLC/firmware
Works/Tests/DB


 
There are no files on this page.[Display files/form]
There is no comment on this page. [Display comments/form]