mirror of
https://github.com/qgis/QGIS.git
synced 2025-05-02 00:05:04 -04:00
Since the underlying issues with the Python bindings are now fixed, in most cases we can safely default to allowing an algorithm to run in a background thread!! So now we make this the default, and require individual algorithms which are NOT thread safe to declare this. This includes algorithms which directly manipulate the current project or layers (such as setting layer styles), alter the selections in layers, or which rely on 3rd party libraries (for now, SAGA and GRASS algorithms are marked as not thread safe... TODO - someone more familiar with these libraries can investigate and remove the flag if appropriate). Also models are marked as non-thread safe. TODO: only flag an individual model as thread-unsafe if any of its child algorithms report this flag.
84 lines
3.1 KiB
Python
84 lines
3.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
***************************************************************************
|
|
SpatialiteExecuteSQL.py
|
|
---------------------
|
|
Date : October 2016
|
|
Copyright : (C) 2016 by Mathieu Pellerin
|
|
Email : nirvn dot asia at gmail dot com
|
|
***************************************************************************
|
|
* *
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
* it under the terms of the GNU General Public License as published by *
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
* (at your option) any later version. *
|
|
* *
|
|
***************************************************************************
|
|
"""
|
|
|
|
__author__ = 'Mathieu Pellerin'
|
|
__date__ = 'October 2016'
|
|
__copyright__ = '(C) 2016, Mathieu Pellerin'
|
|
|
|
# This will get replaced with a git SHA1 when you do a git archive
|
|
|
|
__revision__ = '$Format:%H$'
|
|
|
|
from qgis.core import (QgsDataSourceUri,
|
|
QgsProcessingAlgorithm,
|
|
QgsProcessingException,
|
|
QgsProcessingParameterVectorLayer,
|
|
QgsProcessingParameterString)
|
|
|
|
from processing.algs.qgis.QgisAlgorithm import QgisAlgorithm
|
|
from processing.tools import spatialite
|
|
|
|
|
|
class SpatialiteExecuteSQL(QgisAlgorithm):
|
|
|
|
DATABASE = 'DATABASE'
|
|
SQL = 'SQL'
|
|
|
|
def group(self):
|
|
return self.tr('Database')
|
|
|
|
def groupId(self):
|
|
return 'database'
|
|
|
|
def __init__(self):
|
|
super().__init__()
|
|
|
|
def initAlgorithm(self, config=None):
|
|
self.addParameter(QgsProcessingParameterVectorLayer(self.DATABASE, self.tr('File Database'), [], False, False))
|
|
self.addParameter(QgsProcessingParameterString(self.SQL, self.tr('SQL query'), '', True))
|
|
|
|
def name(self):
|
|
return 'spatialiteexecutesql'
|
|
|
|
def displayName(self):
|
|
return self.tr('SpatiaLite execute SQL')
|
|
|
|
def flags(self):
|
|
return super().flags() | QgsProcessingAlgorithm.FlagNoThreading
|
|
|
|
def processAlgorithm(self, parameters, context, feedback):
|
|
database = self.parameterAsVectorLayer(parameters, self.DATABASE, context)
|
|
databaseuri = database.dataProvider().dataSourceUri()
|
|
uri = QgsDataSourceUri(databaseuri)
|
|
if uri.database() is '':
|
|
if '|layername' in databaseuri:
|
|
databaseuri = databaseuri[:databaseuri.find('|layername')]
|
|
elif '|layerid' in databaseuri:
|
|
databaseuri = databaseuri[:databaseuri.find('|layerid')]
|
|
uri = QgsDataSourceUri('dbname=\'%s\'' % (databaseuri))
|
|
db = spatialite.GeoDB(uri)
|
|
sql = self.parameterAsString(parameters, self.SQL, context).replace('\n', ' ')
|
|
try:
|
|
db._exec_sql_and_commit(str(sql))
|
|
except spatialite.DbError as e:
|
|
raise QgsProcessingException(
|
|
self.tr('Error executing SQL:\n{0}').format(str(e)))
|
|
|
|
return {}
|