Ruslan Polupan
Ruslan Polupan10. Juli 2019 08:29

IMpos-Projekt. Teil 001. Problembeschreibung

Kleine Einführung.

Programmieren ist für mich ein Hobby, um meine Denkprozesse in Schuss zu halten. Daher wird es mit Sicherheit nicht ganz professionelle Lösungsansätze für ein bestimmtes Problem geben. Daher freue ich mich über jeden Hinweis und jede Kritik. Ich habe mich entschieden, mich an der Befüllung des Bereichs Development Diaries zu beteiligen, um meinen eigenen Entwicklungsprozess zu strukturieren und zu disziplinieren.

Das Projekt wurde als ein Satz von Tools konzipiert, um die Einstellungen der M-Pos-Tankstellenbetreibersoftware zu ändern. Dieses Set soll es Mitarbeitern des technischen Supports ermöglichen, schnell Systemeinstellungen gleichzeitig an mehreren (bis zu 200) Objekten zu ändern, ohne die manuelle Ausführung von SQL-Abfragen zu verwenden. Dadurch können auch Nicht-IT-Mitarbeiter Einstellungen ändern, wodurch Zeit für den technischen Support frei wird, um dringendere Probleme zu lösen.


Als Datenbanken werden Firebird in der aktuellen Version 3.0.4 verwendet.

iMpos (MPos Instruments) setzt die Verwendung der folgenden Datenbanktreiber voraus:

  • QIBASE , um mit der zentralen Datenbank und den Tankstellendatenbanken zu arbeiten. Die Treibermontage wird hier beschrieben.
  • QSQLLITE zum Speichern aktueller Programmeinstellungen, Benutzerbasis und Protokollierung durchgeführter Operationen usw. Eine Treibermontage ist nicht erforderlich.

Die aktuelle Aufgabe besteht darin, die Bezeichnung der Kraftstoffarten (Sommer/Winter) in der Datenbank der Tankstellen und auf dem Kassenbon zu ändern. Dazu müssen Sie Änderungen an den Einstellungen in der Tabelle MIGRATEOPTIONS in der Tankstellendatenbank vornehmen. Danach werden beim Schließen der Schicht an der Tankstelle und beim Entfernen des Z-Berichts Änderungen im Fiskalspeicher der Registrierkasse vorgenommen.

Der allgemeine Algorithmus des Programms:

  • Stellen Sie eine Verbindung zur SQLite-Einstellungsdatenbank her. Wenn es fehlt, erstellen Sie;
  • Holen Sie sich Verbindungsparameter zur Zentralbank (zentrale Datenbank). Wenn nicht vorhanden, erstellen Sie einen neuen Eintrag und verbinden Sie ihn;
  • Wenn eine Benutzeridentifikation erforderlich ist, rufen Sie das Identifikationsfenster auf. Führen Sie eine Protokollierung über den Eingang durch;
  • Starten des Hauptfensters der Anwendung;
  • Aufruf der Dialogbox Brennstoffnamen;
  • Anzeige einer Liste von in Betrieb befindlichen Tankstellen mit der Möglichkeit für den Benutzer, einzelne Tankstellen, eine separate Region, alle Tankstellen auszuwählen;
  • erhalten Sie eine Liste ausgewählter Tankstellen;
  • Abrufen der Verbindungsparameter zur Datenbank jeder Tankstelle;
  • den Benutzer nach weiteren Aktionen fragen Namen anzeigen oder Namen festlegen ;
  • Verbinden Sie sich in einem eigenen Thread mit jeder Tankstelle, je nach Aufgabenstellung entweder Daten von der Tankstelle holen (SELECT) oder installieren (UPDATE). In Bearbeitung, zeigt den aktuellen Status der Anfrage sowie den Status ihrer Ausführung an.
  • nach erfolgreichem Empfang der Titelliste diese anzeigen und die Möglichkeit bieten, Informationen auszudrucken oder in einer *.xlsx-Datei zu speichern.
  • beim Parametrieren den Prozess- und Fertigstellungsstatus anzeigen. melden Sie sich bei der SQLite-Datenbank an;
Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Дмитрий
  • 10. Juli 2019 09:25

Исправьте опечатку:
"iMpos (MPos Instruments) предполагает использование слКдующий драйверов баз данных:"

Ruslan Polupan
  • 10. Juli 2019 10:45

Спасибо, исправил.

Evgenii Legotckoi
  • 11. Juli 2019 03:35

Вопрос есть. Базы пользователей в SQLite. Там хранятся логины и пароли поьлзователей? Или просто какая-то общая информация с настройками под конкретного пользователя?

Ruslan Polupan
  • 11. Juli 2019 03:47

Пароль пользователя программы. Для отслеживания кто и когда сделал изменения и все. Пароли к базам хранятся самих базах и в зашифрованном виде. Ну и настройки системы хранятся там. а также логи действия и сформированные скрипты.

Evgenii Legotckoi
  • 11. Juli 2019 03:50

Понятно, а просто шифруете одни пароли, или сразу всю базу данных SQLite? Насколько знаю, есть плагин для шифрования SQLite базы данных.

Ruslan Polupan
  • 11. Juli 2019 03:56

Задумывался над этим, но в свете текщих задач в этом нет особой необходимости.

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken