1 /****************************************************************************
2 **
3 ** Copyright (C) 2016 The Qt Company Ltd.
4 ** Contact: https://www.qt.io/licensing/
5 **
6 ** This file is part of the documentation of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:BSD$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and The Qt Company. For licensing terms
14 ** and conditions see https://www.qt.io/terms-conditions. For further
15 ** information use the contact form at https://www.qt.io/contact-us.
16 **
17 ** BSD License Usage
18 ** Alternatively, you may use this file under the terms of the BSD license
19 ** as follows:
20 **
21 ** "Redistribution and use in source and binary forms, with or without
22 ** modification, are permitted provided that the following conditions are
23 ** met:
24 **   * Redistributions of source code must retain the above copyright
25 **     notice, this list of conditions and the following disclaimer.
26 **   * Redistributions in binary form must reproduce the above copyright
27 **     notice, this list of conditions and the following disclaimer in
28 **     the documentation and/or other materials provided with the
29 **     distribution.
30 **   * Neither the name of The Qt Company Ltd nor the names of its
31 **     contributors may be used to endorse or promote products derived
32 **     from this software without specific prior written permission.
33 **
34 **
35 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
36 ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
37 ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
38 ** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
39 ** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40 ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41 ** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
42 ** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
43 ** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
44 ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
45 ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
46 **
47 ** $QT_END_LICENSE$
48 **
49 ****************************************************************************/
50 #include <QSqlDatabase>
51 #include <QSqlQuery>
52 #include <QSqlDriver>
53 #include <QDebug>
54 
openDatabase()55 void openDatabase()
56 {
57 //! [0]
58 // WRONG
59 QSqlDatabase db = QSqlDatabase::database("sales");
60 QSqlQuery query("SELECT NAME, DOB FROM EMPLOYEES", db);
61 QSqlDatabase::removeDatabase("sales"); // will output a warning
62 // "db" is now a dangling invalid database connection,
63 // "query" contains an invalid result set
64 //! [0]
65 }
66 
removeDatabase()67 void removeDatabase()
68 {
69 //! [1]
70 {
71     QSqlDatabase db = QSqlDatabase::database("sales");
72     QSqlQuery query("SELECT NAME, DOB FROM EMPLOYEES", db);
73 }
74 // Both "db" and "query" are destroyed because they are out of scope
75 QSqlDatabase::removeDatabase("sales"); // correct
76 //! [1]
77 }
78 
setmyDatabase()79 void setmyDatabase()
80 {
81 //! [3]
82 // ...
83 QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
84 db.setDatabaseName("DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};FIL={MS Access};DBQ=myaccessfile.mdb");
85 if (db.open()) {
86     // success!
87 }
88 // ...
89 //! [3]
90 }
91 
92 // ...
93 // MySQL connection
dbConnect()94 void dbConnect()
95 {
96 QSqlDatabase db;
97 //! [4]
98 db.setConnectOptions("SSL_KEY=client-key.pem;SSL_CERT=client-cert.pem;SSL_CA=ca-cert.pem;CLIENT_IGNORE_SPACE=1"); // use an SSL connection to the server
99 if (!db.open()) {
100     db.setConnectOptions(); // clears the connect option string
101     // ...
102 }
103 // ...
104 // PostgreSQL connection
105 db.setConnectOptions("requiressl=1"); // enable PostgreSQL SSL connections
106 if (!db.open()) {
107     db.setConnectOptions(); // clear options
108     // ...
109 }
110 // ...
111 // ODBC connection
112 db.setConnectOptions("SQL_ATTR_ACCESS_MODE=SQL_MODE_READ_ONLY;SQL_ATTR_TRACE=SQL_OPT_TRACE_ON"); // set ODBC options
113 if (!db.open()) {
114     db.setConnectOptions(); // don't try to set this option
115     // ...
116 }
117 }
118 //! [4]
119 
dbQdebug()120 void dbQdebug()
121 {
122 //! [8]
123 QSqlDatabase db;
124 qDebug() << db.isValid();    // Returns false
125 
126 db = QSqlDatabase::database("sales");
127 qDebug() << db.isValid();    // Returns \c true if "sales" connection exists
128 
129 QSqlDatabase::removeDatabase("sales");
130 qDebug() << db.isValid();    // Returns false
131 //! [8]
132 }
133