Qt 6.x
The Qt SDK
Loading...
Searching...
No Matches
qsqldriver.h
Go to the documentation of this file.
1// Copyright (C) 2016 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4#ifndef QSQLDRIVER_H
5#define QSQLDRIVER_H
6
7#include <QtSql/qtsqlglobal.h>
8#include <QtCore/qobject.h>
9#include <QtCore/qstring.h>
10#include <QtCore/qstringlist.h>
11
13
14
15class QSqlDatabase;
17class QSqlError;
18class QSqlField;
19class QSqlIndex;
20class QSqlRecord;
21class QSqlResult;
22class QVariant;
23
24class Q_SQL_EXPORT QSqlDriver : public QObject
25{
26 friend class QSqlDatabase;
27 friend class QSqlResultPrivate;
29 Q_DECLARE_PRIVATE(QSqlDriver)
30
31public:
32 enum DriverFeature { Transactions, QuerySize, BLOB, Unicode, PreparedQueries,
33 NamedPlaceholders, PositionalPlaceholders, LastInsertId,
34 BatchOperations, SimpleLocking, LowPrecisionNumbers,
35 EventNotifications, FinishQuery, MultipleResultSets, CancelQuery };
36
37 enum StatementType { WhereStatement, SelectStatement, UpdateStatement,
38 InsertStatement, DeleteStatement };
39
40 enum IdentifierType { FieldName, TableName };
41
42 enum NotificationSource { UnknownSource, SelfSource, OtherSource };
43
44 enum DbmsType {
55 };
56
57 explicit QSqlDriver(QObject *parent = nullptr);
59 virtual bool isOpen() const;
60 bool isOpenError() const;
61
62 virtual bool beginTransaction();
63 virtual bool commitTransaction();
64 virtual bool rollbackTransaction();
65 virtual QStringList tables(QSql::TableType tableType) const;
66 virtual QSqlIndex primaryIndex(const QString &tableName) const;
67 virtual QSqlRecord record(const QString &tableName) const;
68 virtual QString formatValue(const QSqlField &field, bool trimStrings = false) const;
69
70 virtual QString escapeIdentifier(const QString &identifier, IdentifierType type) const;
71 virtual QString sqlStatement(StatementType type, const QString &tableName,
72 const QSqlRecord &rec, bool preparedStatement) const;
73
74 QSqlError lastError() const;
75
76 virtual QVariant handle() const;
77 virtual bool hasFeature(DriverFeature f) const = 0;
78 virtual void close() = 0;
79 virtual QSqlResult *createResult() const = 0;
80
81 virtual bool open(const QString &db,
82 const QString &user = QString(),
83 const QString &password = QString(),
84 const QString &host = QString(),
85 int port = -1,
86 const QString &connOpts = QString()) = 0;
87 virtual bool subscribeToNotification(const QString &name);
88 virtual bool unsubscribeFromNotification(const QString &name);
89 virtual QStringList subscribedToNotifications() const;
90
91 virtual bool isIdentifierEscaped(const QString &identifier, IdentifierType type) const;
92 virtual QString stripDelimiters(const QString &identifier, IdentifierType type) const;
93
94 void setNumericalPrecisionPolicy(QSql::NumericalPrecisionPolicy precisionPolicy);
95 QSql::NumericalPrecisionPolicy numericalPrecisionPolicy() const;
96
97 DbmsType dbmsType() const;
98 virtual int maximumIdentifierLength(IdentifierType type) const;
99public Q_SLOTS:
100 virtual bool cancelQuery();
101
104
105protected:
107 virtual void setOpen(bool o);
108 virtual void setOpenError(bool e);
109 virtual void setLastError(const QSqlError& e);
110
111
112private:
113 Q_DISABLE_COPY(QSqlDriver)
114};
115
117
118#endif // QSQLDRIVER_H
\inmodule QtCore
Definition qobject.h:90
The QSqlDatabase class handles a connection to a database.
The QSqlDriver class is an abstract base class for accessing specific SQL databases.
Definition qsqldriver.h:25
IdentifierType
This enum contains a list of SQL identifier types.
Definition qsqldriver.h:40
virtual QSqlResult * createResult() const =0
Creates an empty SQL result on the database.
StatementType
This enum contains a list of SQL statement (or clause) types the driver can create.
Definition qsqldriver.h:37
@ SelectStatement
Definition qsqldriver.h:37
DriverFeature
This enum contains a list of features a driver might support.
Definition qsqldriver.h:32
@ BatchOperations
Definition qsqldriver.h:34
virtual void close()=0
Derived classes must reimplement this pure virtual function in order to close the database connection...
NotificationSource
This enum contains a list of SQL notification sources.
Definition qsqldriver.h:42
void notification(const QString &name, QSqlDriver::NotificationSource source, const QVariant &payload)
virtual bool open(const QString &db, const QString &user=QString(), const QString &password=QString(), const QString &host=QString(), int port=-1, const QString &connOpts=QString())=0
Derived classes must reimplement this pure virtual function to open a database connection on database...
virtual bool hasFeature(DriverFeature f) const =0
Returns true if the driver supports feature feature; otherwise returns false.
The QSqlError class provides SQL database error information.
Definition qsqlerror.h:17
The QSqlField class manipulates the fields in SQL database tables and views.
Definition qsqlfield.h:19
The QSqlIndex class provides functions to manipulate and describe database indexes.
Definition qsqlindex.h:16
The QSqlRecord class encapsulates a database record.
Definition qsqlrecord.h:20
The QSqlResult class provides an abstract interface for accessing data from specific SQL databases.
Definition qsqlresult.h:25
\inmodule QtCore
\macro QT_RESTRICTED_CAST_FROM_ASCII
Definition qstring.h:127
\inmodule QtCore
Definition qvariant.h:64
double e
NumericalPrecisionPolicy
Definition qtsqlglobal.h:44
Combined button and popup list for selecting options.
EGLOutputPortEXT port
GLuint64 GLenum void * handle
GLfloat GLfloat f
GLenum type
GLuint name
GLsizei GLsizei GLchar * source
#define Q_OBJECT
#define Q_SLOTS
#define Q_SIGNALS
QMimeDatabase db
[0]
MyRecord record(int row) const
[0]
IUIAutomationTreeWalker __RPC__deref_out_opt IUIAutomationElement ** parent