mirror of
				https://github.com/qgis/QGIS.git
				synced 2025-10-25 00:05:24 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			90 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			3.4 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'
 | |
| 
 | |
| from qgis.core import (QgsDataSourceUri,
 | |
|                        QgsProcessing,
 | |
|                        QgsProcessingAlgorithm,
 | |
|                        QgsProcessingException,
 | |
|                        QgsProcessingParameterVectorLayer,
 | |
|                        QgsProcessingParameterString,
 | |
|                        QgsProviderRegistry,
 | |
|                        QgsProviderConnectionException)
 | |
| 
 | |
| from processing.algs.qgis.QgisAlgorithm import QgisAlgorithm
 | |
| 
 | |
| 
 | |
| 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'), types=[QgsProcessing.TypeVector], optional=False))
 | |
|         self.addParameter(QgsProcessingParameterString(self.SQL, self.tr('SQL query'), multiLine=True))
 | |
| 
 | |
|     def name(self):
 | |
|         return 'spatialiteexecutesql'
 | |
| 
 | |
|     def displayName(self):
 | |
|         return self.tr('SpatiaLite execute SQL')
 | |
| 
 | |
|     def shortDescription(self):
 | |
|         return self.tr('Executes a SQL command on a SpatiaLite database')
 | |
| 
 | |
|     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))
 | |
| 
 | |
|         try:
 | |
|             md = QgsProviderRegistry.instance().providerMetadata('spatialite')
 | |
|             conn = md.createConnection(uri.uri(), {})
 | |
|         except QgsProviderConnectionException:
 | |
|             raise QgsProcessingException(self.tr('Could not connect to {}').format(uri.uri()))
 | |
| 
 | |
|         sql = self.parameterAsString(parameters, self.SQL, context).replace('\n', ' ')
 | |
|         try:
 | |
|             conn.executeSql(sql)
 | |
|         except QgsProviderConnectionException as e:
 | |
|             raise QgsProcessingException(self.tr('Error executing SQL:\n{0}').format(e))
 | |
| 
 | |
|         return {}
 |