Evgenii Legotckoi
Evgenii Legotckoi20. November 2015 10:23

Qt/C++ - Lektion 040. Datentypen in verschiedenen Datenbanken in Qt

Wenn Sie eine Anwendung unter Qt entwickeln, die mit Datenbanken arbeiten soll, müssen Sie die Nuance berücksichtigen, dass der Qt -Treiber für die Zieldatenbank möglicherweise nicht alle Arten von Daten unterstützt, die Sie möglicherweise eingeben Ihre Datenbank. Eines der ähnlichen Beispiele, auf das einer der Leser der Website gestoßen ist, war beispielsweise ein Problem mit der Anzeige des Datentyps DECIMAL durch QSqlTableModel . Bei der Entwicklung einer Anwendung im C++ Builder hingegen wurde dieser Datentyp perfekt in der Ansicht dargestellt.

Und die Arbeit wurde mit der MS SQL -Datenbank erledigt, für die der ODBC -Treiber verwendet wurde. Die Ergebnisse der Ausführung von Anwendungen auf C++ Builder und auf Qt sind in den folgenden Abbildungen dargestellt. Der Unterschied im Aussehen der Tabellen besteht darin, dass in einer Qt-Anwendung keine Werte in der Ansicht vorhanden sind, bei denen der Datentyp in der Datenbank als DECIMAL deklariert wurde.


C++ Builder-Anwendung – Alle Spalten sind ausgefüllt

Qt-Anwendung - fehlende Werte in DECIMAL-Spalten

Datentypen in der Dokumentation prüfen

Beim Überprüfen der unterstützten Datentypen auf der Seite in der offiziellen Dokumentation finden wir die Datentypen, die vom ausgewählten Treiber und unterstützt werden Passen Sie die Datenbank entsprechend den Datentypen an, die von demselben Treiber unterstützt werden.

ODBC-Datentypen

ODBC-Datentyp Beschreibung des SQL-Typs Empfohlene Eingabe (C++- oder Qt-Datentyp)
BIT Boolesch BOOL
TINYINT 8-Bit-Ganzzahl typedef qint8
SMALLINT 16-Bit-Ganzzahl mit Vorzeichen typedef qint16
INTEGER 32-Bit-Ganzzahl mit Vorzeichen typedef qint32
BIGINT 64-Bit-Ganzzahl mit Vorzeichen typedef qint64
REAL 32-Bit-Gleitkommazahl mit einfacher Genauigkeit Standardmäßig ist die Zuordnung zu QString
FLOAT 64-Bit-Double-Floating-Point Standardmäßig ist die Zuordnung zu QString
DOUBLE 64-Bit-Double-Floating-Point Standardmäßig ist die Zuordnung zu QString
CHAR Zeichenkette Zugeordnet zu QString
VARCHAR Zeichenkette Zugeordnet zu QString
LONGVARCHAR Zeichenkette Zugeordnet zu QString
CLOB Character großes Zeichenfolgenobjekt Zugeordnet zu QString
DATE Zeichenkette Zugeordnet zu QDate
TIME Zeichen Zeit, Zeichenkette Zugeordnet zu QTime
TIMESTAMP Zeichen Zeit, Zeichenkette Zugeordnet zu QDateTime

Insgesamt

Infolgedessen wurde der Typ DECIMAL einfach in den Typ INTEGER geändert, und alles ging los.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
A
ALO1ZE19. Oktober 2024 08:19
Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов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> в заголовочном файле не работает валидатор.
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