mirror of
				https://github.com/qgis/QGIS.git
				synced 2025-10-25 00:05:24 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			250 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			250 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- coding: utf-8 -*-
 | |
| 
 | |
| """
 | |
| /***************************************************************************
 | |
| Name                 : DB Manager
 | |
| Description          : Database manager plugin for QGIS
 | |
| Date                 : May 23, 2011
 | |
| copyright            : (C) 2011 by Giuseppe Sucameli
 | |
| email                : brush.tyler@gmail.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.                                   *
 | |
|  *                                                                         *
 | |
|  ***************************************************************************/
 | |
| """
 | |
| 
 | |
| # this will disable the dbplugin if the connector raise an ImportError
 | |
| from .connector import SpatiaLiteDBConnector
 | |
| 
 | |
| from PyQt4.QtCore import *
 | |
| from PyQt4.QtGui import *
 | |
| 
 | |
| from ..plugin import DBPlugin, Database, Table, VectorTable, RasterTable, TableField, TableConstraint, TableIndex, TableTrigger
 | |
| try:
 | |
| 	from . import resources_rc
 | |
| except ImportError:
 | |
| 	pass
 | |
| 
 | |
| from ..html_elems import HtmlParagraph, HtmlTable
 | |
| 
 | |
| 
 | |
| def classFactory():
 | |
| 	return SpatiaLiteDBPlugin
 | |
| 
 | |
| class SpatiaLiteDBPlugin(DBPlugin):
 | |
| 
 | |
| 	@classmethod
 | |
| 	def icon(self):
 | |
| 		return QIcon(":/db_manager/spatialite/icon")
 | |
| 
 | |
| 	@classmethod
 | |
| 	def typeName(self):
 | |
| 		return 'spatialite'
 | |
| 
 | |
| 	@classmethod
 | |
| 	def typeNameString(self):
 | |
| 		return 'SpatiaLite'
 | |
| 
 | |
| 	@classmethod
 | |
| 	def providerName(self):
 | |
| 		return 'spatialite'
 | |
| 
 | |
| 	@classmethod
 | |
| 	def connectionSettingsKey(self):
 | |
| 		return '/SpatiaLite/connections'
 | |
| 
 | |
| 	def databasesFactory(self, connection, uri):
 | |
| 		return SLDatabase(connection, uri)
 | |
| 
 | |
| 	def connect(self, parent=None):
 | |
| 		conn_name = self.connectionName()
 | |
| 		settings = QSettings()
 | |
| 		settings.beginGroup( u"/%s/%s" % (self.connectionSettingsKey(), conn_name) )
 | |
| 
 | |
| 		if not settings.contains( "sqlitepath" ): # non-existent entry?
 | |
| 			raise InvalidDataException( u'there is no defined database connection "%s".' % conn_name )
 | |
| 
 | |
| 		database = settings.value("sqlitepath")
 | |
| 
 | |
| 		import qgis.core
 | |
| 		uri = qgis.core.QgsDataSourceURI()
 | |
| 		uri.setDatabase(database)
 | |
| 		return self.connectToUri(uri)
 | |
| 
 | |
| 
 | |
| class SLDatabase(Database):
 | |
| 	def __init__(self, connection, uri):
 | |
| 		Database.__init__(self, connection, uri)
 | |
| 
 | |
| 	def connectorsFactory(self, uri):
 | |
| 		return SpatiaLiteDBConnector(uri)
 | |
| 
 | |
| 
 | |
| 	def dataTablesFactory(self, row, db, schema=None):
 | |
| 		return SLTable(row, db, schema)
 | |
| 
 | |
| 	def vectorTablesFactory(self, row, db, schema=None):
 | |
| 		return SLVectorTable(row, db, schema)
 | |
| 
 | |
| 	def rasterTablesFactory(self, row, db, schema=None):
 | |
| 		return SLRasterTable(row, db, schema)
 | |
| 
 | |
| 
 | |
| 	def info(self):
 | |
| 		from .info_model import SLDatabaseInfo
 | |
| 		return SLDatabaseInfo(self)
 | |
| 
 | |
| 	def sqlResultModel(self, sql, parent):
 | |
| 		from .data_model import SLSqlResultModel
 | |
| 		return SLSqlResultModel(self, sql, parent)
 | |
| 
 | |
| 
 | |
| 	def registerDatabaseActions(self, mainWindow):
 | |
| 		action = QAction(self.tr("Run &Vacuum"), self)
 | |
| 		mainWindow.registerAction( action, self.tr("&Database"), self.runVacuumActionSlot )
 | |
| 
 | |
| 		Database.registerDatabaseActions(self, mainWindow)
 | |
| 
 | |
| 	def runVacuumActionSlot(self, item, action, parent):
 | |
| 		QApplication.restoreOverrideCursor()
 | |
| 		try:
 | |
| 			if not isinstance(item, (DBPlugin, Table)) or item.database() == None:
 | |
| 				parent.infoBar.pushMessage(self.tr("No database selected or you are not connected to it."), QgsMessageBar.INFO, parent.iface.messageTimeout())
 | |
| 				return
 | |
| 		finally:
 | |
| 			QApplication.setOverrideCursor(Qt.WaitCursor)
 | |
| 
 | |
| 		self.runVacuum()
 | |
| 
 | |
| 	def runVacuum(self):
 | |
| 		self.database().aboutToChange()
 | |
| 		self.database().connector.runVacuum()
 | |
| 		self.database().refresh()
 | |
| 
 | |
| 
 | |
| 	def runAction(self, action):
 | |
| 		action = unicode(action)
 | |
| 
 | |
| 		if action.startswith( "vacuum/" ):
 | |
| 			if action == "vacuum/run":
 | |
| 				self.runVacuum()
 | |
| 				return True
 | |
| 
 | |
| 		return Database.runAction(self, action)
 | |
| 
 | |
| 
 | |
| class SLTable(Table):
 | |
| 	def __init__(self, row, db, schema=None):
 | |
| 		Table.__init__(self, db, None)
 | |
| 		self.name, self.isView, self.isSysTable = row
 | |
| 
 | |
| 
 | |
| 	def tableFieldsFactory(self, row, table):
 | |
| 		return SLTableField(row, table)
 | |
| 
 | |
| 	def tableIndexesFactory(self, row, table):
 | |
| 		return SLTableIndex(row, table)
 | |
| 
 | |
| 	def tableTriggersFactory(self, row, table):
 | |
| 		return SLTableTrigger(row, table)
 | |
| 
 | |
| 
 | |
| 	def tableDataModel(self, parent):
 | |
| 		from .data_model import SLTableDataModel
 | |
| 		return SLTableDataModel(self, parent)
 | |
| 
 | |
| 
 | |
| class SLVectorTable(SLTable, VectorTable):
 | |
| 	def __init__(self, row, db, schema=None):
 | |
| 		SLTable.__init__(self, row[:-5], db, schema)
 | |
| 		VectorTable.__init__(self, db, schema)
 | |
| 		# SpatiaLite does case-insensitive checks for table names, but the
 | |
| 		# SL provider didn't do the same in QGis < 1.9, so self.geomTableName
 | |
| 		# stores the table name like stored in the geometry_columns table
 | |
| 		self.geomTableName, self.geomColumn, self.geomType, self.geomDim, self.srid = row[-5:]
 | |
| 
 | |
| 	def uri(self):
 | |
| 		uri = self.database().uri()
 | |
| 		uri.setDataSource('', self.geomTableName, self.geomColumn)
 | |
| 		return uri
 | |
| 
 | |
| 	def hasSpatialIndex(self, geom_column=None):
 | |
| 		geom_column = geom_column if geom_column != None else self.geomColumn
 | |
| 		return self.database().connector.hasSpatialIndex( (self.schemaName(), self.name), geom_column )
 | |
| 
 | |
| 	def createSpatialIndex(self, geom_column=None):
 | |
| 		self.aboutToChange()
 | |
| 		ret = VectorTable.createSpatialIndex(self, geom_column)
 | |
| 		if ret != False:
 | |
| 			self.database().refresh()
 | |
| 		return ret
 | |
| 
 | |
| 	def deleteSpatialIndex(self, geom_column=None):
 | |
| 		self.aboutToChange()
 | |
| 		ret = VectorTable.deleteSpatialIndex(self, geom_column)
 | |
| 		if ret != False:
 | |
| 			self.database().refresh()
 | |
| 		return ret
 | |
| 
 | |
| 	def refreshTableEstimatedExtent(self):
 | |
| 		return
 | |
| 
 | |
| 
 | |
| 	def runAction(self, action):
 | |
| 		if SLTable.runAction(self, action):
 | |
| 			return True
 | |
| 		return VectorTable.runAction(self, action)
 | |
| 
 | |
| 
 | |
| class SLRasterTable(SLTable, RasterTable):
 | |
| 	def __init__(self, row, db, schema=None):
 | |
| 		SLTable.__init__(self, row[:-3], db, schema)
 | |
| 		RasterTable.__init__(self, db, schema)
 | |
| 		self.prefixName, self.geomColumn, self.srid = row[-3:]
 | |
| 		self.geomType = 'RASTER'
 | |
| 
 | |
| 	#def info(self):
 | |
| 		#from .info_model import SLRasterTableInfo
 | |
| 		#return SLRasterTableInfo(self)
 | |
| 
 | |
| 	def gdalUri(self):
 | |
| 		uri = self.database().uri()
 | |
| 		gdalUri = u'RASTERLITE:%s,table=%s' % (uri.database(), self.prefixName)
 | |
| 		return gdalUri
 | |
| 
 | |
| 	def mimeUri(self):
 | |
| 		uri = u"raster:gdal:%s:%s" % (self.name, self.gdalUri())
 | |
| 		return uri
 | |
| 
 | |
| 	def toMapLayer(self):
 | |
| 		from qgis.core import QgsRasterLayer
 | |
| 		rl = QgsRasterLayer(self.gdalUri(), self.name)
 | |
| 		if rl.isValid():
 | |
| 			rl.setContrastEnhancementAlgorithm("StretchToMinimumMaximum")
 | |
| 		return rl
 | |
| 
 | |
| 
 | |
| class SLTableField(TableField):
 | |
| 	def __init__(self, row, table):
 | |
| 		TableField.__init__(self, table)
 | |
| 		self.num, self.name, self.dataType, self.notNull, self.default, self.primaryKey = row
 | |
| 		self.hasDefault = self.default != None
 | |
| 
 | |
| class SLTableIndex(TableIndex):
 | |
| 	def __init__(self, row, table):
 | |
| 		TableIndex.__init__(self, table)
 | |
| 		self.num, self.name, self.isUnique, self.columns = row
 | |
| 
 | |
| class SLTableTrigger(TableTrigger):
 | |
| 	def __init__(self, row, table):
 | |
| 		TableTrigger.__init__(self, table)
 | |
| 		self.name, self.function = row
 | |
| 
 |