Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qsqldatabase.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 QSQLDATABASE_H
5#define QSQLDATABASE_H
6
7#include <QtSql/qtsqlglobal.h>
8#include <QtCore/qmetaobject.h>
9#include <QtCore/qstring.h>
10
11// clazy:excludeall=qproperty-without-notify
13
14
15class QSqlError;
16class QSqlDriver;
17class QSqlIndex;
18class QSqlRecord;
19class QSqlQuery;
21class QThread;
22
23class Q_SQL_EXPORT QSqlDriverCreatorBase
24{
25public:
27 virtual QSqlDriver *createObject() const = 0;
28};
29
30template <class T>
32{
33public:
34 QSqlDriver *createObject() const override { return new T; }
35};
36
37class Q_SQL_EXPORT QSqlDatabase
38{
40public:
41 Q_PROPERTY(QSql::NumericalPrecisionPolicy numericalPrecisionPolicy READ numericalPrecisionPolicy WRITE setNumericalPrecisionPolicy)
42
46
47 QSqlDatabase &operator=(const QSqlDatabase &other);
48
49 bool open();
50 bool open(const QString& user, const QString& password);
51 void close();
52 bool isOpen() const;
53 bool isOpenError() const;
55 QSqlIndex primaryIndex(const QString& tablename) const;
56 QSqlRecord record(const QString& tablename) const;
57#if QT_DEPRECATED_SINCE(6, 6)
58 QT_DEPRECATED_VERSION_X_6_6("Use QSqlQuery::exec() instead.")
59 QSqlQuery exec(const QString& query = QString()) const;
60#endif
61 QSqlError lastError() const;
62 bool isValid() const;
63
64 bool transaction();
65 bool commit();
66 bool rollback();
67
68 void setDatabaseName(const QString& name);
69 void setUserName(const QString& name);
70 void setPassword(const QString& password);
71 void setHostName(const QString& host);
72 void setPort(int p);
73 void setConnectOptions(const QString& options = QString());
74 QString databaseName() const;
75 QString userName() const;
76 QString password() const;
77 QString hostName() const;
78 QString driverName() const;
79 int port() const;
80 QString connectOptions() const;
81 QString connectionName() const;
82 void setNumericalPrecisionPolicy(QSql::NumericalPrecisionPolicy precisionPolicy);
83 QSql::NumericalPrecisionPolicy numericalPrecisionPolicy() const;
84 bool moveToThread(QThread *targetThread);
85 QThread *currentThread() const;
86
87 QSqlDriver* driver() const;
88
89 static const char *defaultConnection;
90
91 static QSqlDatabase addDatabase(const QString& type,
92 const QString& connectionName = QLatin1StringView(defaultConnection));
93 static QSqlDatabase addDatabase(QSqlDriver* driver,
94 const QString& connectionName = QLatin1StringView(defaultConnection));
95 static QSqlDatabase cloneDatabase(const QSqlDatabase &other, const QString& connectionName);
96 static QSqlDatabase cloneDatabase(const QString &other, const QString& connectionName);
97 static QSqlDatabase database(const QString& connectionName = QLatin1StringView(defaultConnection),
98 bool open = true);
99 static void removeDatabase(const QString& connectionName);
100 static bool contains(const QString& connectionName = QLatin1StringView(defaultConnection));
101 static QStringList drivers();
102 static QStringList connectionNames();
103 static void registerSqlDriver(const QString &name, QSqlDriverCreatorBase *creator);
104 static bool isDriverAvailable(const QString &name);
105
106protected:
107 explicit QSqlDatabase(const QString& type);
108 explicit QSqlDatabase(QSqlDriver* driver);
109
110private:
113};
114
115#ifndef QT_NO_DEBUG_STREAM
116Q_SQL_EXPORT QDebug operator<<(QDebug, const QSqlDatabase &);
117#endif
118
120
121#endif // QSQLDATABASE_H
\inmodule QtCore
The QSqlDatabase class handles a connection to a database.
static const char * defaultConnection
The QSqlDriverCreatorBase class is the base class for SQL driver factories.
virtual QSqlDriver * createObject() const =0
Reimplement this function to returns a new instance of a QSqlDriver subclass.
virtual ~QSqlDriverCreatorBase()
Destroys the SQL driver creator object.
The QSqlDriverCreator class is a template class that provides a SQL driver factory for a specific dri...
QSqlDriver * createObject() const override
\reimp
The QSqlDriver class is an abstract base class for accessing specific SQL databases.
Definition qsqldriver.h:26
The QSqlError class provides SQL database error information.
Definition qsqlerror.h:17
The QSqlIndex class provides functions to manipulate and describe database indexes.
Definition qsqlindex.h:18
The QSqlQuery class provides a means of executing and manipulating SQL statements.
Definition qsqlquery.h:24
The QSqlRecord class encapsulates a database record.
Definition qsqlrecord.h:20
\inmodule QtCore
\macro QT_RESTRICTED_CAST_FROM_ASCII
Definition qstring.h:129
@ Tables
Definition qtsqlglobal.h:36
NumericalPrecisionPolicy
Definition qtsqlglobal.h:43
Combined button and popup list for selecting options.
EGLOutputPortEXT port
static bool contains(const QJsonArray &haystack, unsigned needle)
Definition qopengl.cpp:116
GLint GLint GLint GLint GLsizei GLsizei GLsizei GLboolean commit
GLenum type
GLuint name
GLenum query
GLfloat GLfloat p
[1]
Q_SQL_EXPORT QDebug operator<<(QDebug, const QSqlDatabase &)
#define QT_DEPRECATED_VERSION_X_6_6(text)
#define Q_PROPERTY(...)
#define Q_GADGET
file open(QIODevice::ReadOnly)
myObject moveToThread(QApplication::instance() ->thread())
[6]
MyRecord record(int row) const
[0]
QSharedPointer< T > other(t)
[5]
dialog exec()
QItemEditorCreatorBase * creator
proxy setPassword("password")
proxy setHostName("proxy.example.com")
proxy setPort(1080)
void removeDatabase()