QGIS API Documentation  3.16.0-Hannover (43b64b13f3)
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
qgsspatialiteutils.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgsspatialiteutils.cpp
3  -------------------
4  begin : Nov, 2017
5  copyright : (C) 2017 by Matthias Kuhn
6  email : matthias@opengis.ch
7  ***************************************************************************/
8 
9 /***************************************************************************
10  * *
11  * This program is free software; you can redistribute it and/or modify *
12  * it under the terms of the GNU General Public License as published by *
13  * the Free Software Foundation; either version 2 of the License, or *
14  * (at your option) any later version. *
15  * *
16  ***************************************************************************/
17 
18 
19 #include "qgsspatialiteutils.h"
20 #include "qgslogger.h"
21 
22 #include <sqlite3.h>
23 #include <spatialite.h>
24 
25 // Define this variable to print all spatialite SQL statements
26 #ifdef SPATIALITE_PRINT_ALL_SQL
27 // Debugging code
28 #include <QDebug>
29 #include <QThread>
30 static int trace_callback( unsigned, void *ctx, void *p, void * )
31 {
32  sqlite3_stmt *stmt = ( sqlite3_stmt * )p;
33  char *sql = sqlite3_expanded_sql( stmt );
34  qDebug() << "SPATIALITE" << QThread::currentThreadId() << ( sqlite3 * ) ctx << sql;
35  sqlite3_free( sql );
36  return 0;
37 }
38 #endif
39 
40 
41 int spatialite_database_unique_ptr::open( const QString &path )
42 {
43  auto &deleter = get_deleter();
44  deleter.mSpatialiteContext = spatialite_alloc_connection();
45 
46  sqlite3 *database = nullptr;
47  int result = sqlite3_open( path.toUtf8(), &database );
48  std::unique_ptr< sqlite3, QgsSpatialiteCloser>::reset( database );
49 
50  if ( result == SQLITE_OK )
51  spatialite_init_ex( database, deleter.mSpatialiteContext, 0 );
52 
53  return result;
54 }
55 
57 {
58  std::unique_ptr< sqlite3, QgsSpatialiteCloser>::reset();
59 }
60 
61 int spatialite_database_unique_ptr::open_v2( const QString &path, int flags, const char *zVfs )
62 {
63  auto &deleter = get_deleter();
64  deleter.mSpatialiteContext = spatialite_alloc_connection();
65 
66  sqlite3 *database = nullptr;
67  int result = sqlite3_open_v2( path.toUtf8(), &database, flags, zVfs );
68  std::unique_ptr< sqlite3, QgsSpatialiteCloser>::reset( database );
69 
70  if ( result == SQLITE_OK )
71  spatialite_init_ex( database, deleter.mSpatialiteContext, 0 );
72 
73 #ifdef SPATIALITE_PRINT_ALL_SQL
74  // Log all queries
75  sqlite3_trace_v2(
76  database,
77  SQLITE_TRACE_STMT,
78  trace_callback,
79  database
80  );
81 #endif
82 
83  return result;
84 }
85 
87 {
88  return QString( sqlite3_errmsg( get() ) );
89 }
90 
92 {
93  sqlite3_stmt *preparedStatement = nullptr;
94  const char *tail = nullptr;
95  const QByteArray sqlUtf8 = sql.toUtf8();
96  resultCode = sqlite3_prepare( get(), sqlUtf8, sqlUtf8.length(), &preparedStatement, &tail );
98  s.reset( preparedStatement );
99  return s;
100 }
101 
103 {
104  int res = sqlite3_close_v2( handle );
105  if ( res != SQLITE_OK )
106  {
107  QgsDebugMsg( QStringLiteral( "sqlite3_close_v2() failed: %1" ).arg( res ) );
108  }
109 
110  spatialite_cleanup_ex( mSpatialiteContext );
111  mSpatialiteContext = nullptr;
112 }
spatialite_database_unique_ptr::open
int open(const QString &path)
Opens the database at the specified file path.
Definition: qgsspatialiteutils.cpp:41
sqlite3
struct sqlite3 sqlite3
Definition: qgscoordinatereferencesystem.h:55
QgsSpatialiteCloser::operator()
void operator()(sqlite3 *database)
Closes an spatialite database.
Definition: qgsspatialiteutils.cpp:102
QgsDebugMsg
#define QgsDebugMsg(str)
Definition: qgslogger.h:38
QgsSpatialiteCloser::mSpatialiteContext
void * mSpatialiteContext
Keep track of the spatialite context.
Definition: qgsspatialiteutils.h:45
spatialite_database_unique_ptr::reset
void reset()
Will close the connection and set the internal pointer to nullptr.
Definition: qgsspatialiteutils.cpp:56
spatialite_database_unique_ptr::open_v2
int open_v2(const QString &path, int flags, const char *zVfs)
Opens the database at the specified file path.
Definition: qgsspatialiteutils.cpp:61
spatialite_database_unique_ptr::errorMessage
QString errorMessage() const
Returns the most recent error message encountered by the database.
Definition: qgsspatialiteutils.cpp:86
qgsspatialiteutils.h
qgslogger.h
sqlite3_statement_unique_ptr
Unique pointer for sqlite3 prepared statements, which automatically finalizes the statement when the ...
Definition: qgssqliteutils.h:70
spatialite_database_unique_ptr::prepare
sqlite3_statement_unique_ptr prepare(const QString &sql, int &resultCode)
Prepares a sql statement, returning the result.
Definition: qgsspatialiteutils.cpp:91