PyQt5 - Gestion de la base de données
La bibliothèque PyQt5 contient QtSqlmodule. Il s'agit d'un système de classes élaboré pour communiquer avec de nombreuses bases de données SQL. SesQSqlDatabasefournit un accès via un objet Connection. Voici la liste des pilotes SQL actuellement disponibles -
N ° Sr. | Type de pilote et description |
---|---|
1 | QDB2 IBM DB2 |
2 | QIBASE Pilote Borland InterBase |
3 | QMYSQL Pilote MySQL |
4 | QOCI Pilote d'interface d'appel Oracle |
5 | QODBC Pilote ODBC (inclut Microsoft SQL Server) |
6 | QPSQL Pilote PostgreSQL |
sept | QSQLITE SQLite version 3 ou supérieure |
8 | QSQLITE2 SQLite version 2 |
Exemple
Pour ce chapitre, une connexion avec une base de données SQLite est établie à l'aide de la méthode statique -
db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sports.db')
Les autres méthodes de la classe QSqlDatabase sont les suivantes -
N ° Sr. | Méthodes et description |
---|---|
1 | setDatabaseName() Définit le nom de la base de données avec laquelle la connexion est recherchée |
2 | setHostName() Définit le nom de l'hôte sur lequel la base de données est installée |
3 | setUserName() Spécifie le nom d'utilisateur pour la connexion |
4 | setPassword() Définit le mot de passe de l'objet de connexion, le cas échéant |
5 | commit() Valide les transactions et renvoie true en cas de succès |
6 | rollback() Annule la transaction de base de données |
sept | close() Ferme la connexion |
QSqlQueryclass a la fonctionnalité pour exécuter et manipuler des commandes SQL. Les requêtes SQL de type DDL et DML peuvent être exécutées. La première étape consiste à créer la base de données SQlite en utilisant les instructions suivantes -
db = QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sportsdatabase.db')
Ensuite, obtenez l'objet Query avec QSqlQuery() et appelez sa méthode la plus importante exec_ (), qui prend comme argument une chaîne contenant une instruction SQL à exécuter.
query = QtSql.QSqlQuery()
query.exec_("create table sportsmen(id int primary key, " "firstname varchar(20), lastname varchar(20))")
Le script suivant crée une base de données SQLite sports.db avec une table de sportifs remplie de cinq enregistrements.
import sys
from PyQt5.QtSql import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def createDB():
db = QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sportsdatabase.db')
if not db.open():
msg = QMessageBox()
msg.setIcon(QMessageBox.Critical)
msg.setText("Error in Database Creation")
retval = msg.exec_()
return False
query = QSqlQuery()
query.exec_("create table sportsmen(
id int primary key, ""firstname varchar(20), lastname varchar(20))")
query.exec_("insert into sportsmen values(101, 'Roger', 'Federer')")
query.exec_("insert into sportsmen values(102, 'Christiano', 'Ronaldo')")
query.exec_("insert into sportsmen values(103, 'Ussain', 'Bolt')")
query.exec_("insert into sportsmen values(104, 'Sachin', 'Tendulkar')")
query.exec_("insert into sportsmen values(105, 'Saina', 'Nehwal')")
return True
if __name__ == '__main__':
app = QApplication(sys.argv)
createDB()
Pour confirmer que la base de données SQLite est créée avec les enregistrements ci-dessus ajoutés dans la table des sportifs, utilisez un utilitaire SQLite Gui appelé SQLiteStudio.
QSqlTableModelLa classe dans PyQt est une interface de haut niveau qui fournit un modèle de données modifiable pour la lecture et l'écriture d'enregistrements dans une seule table. Ce modèle est utilisé pour remplir unQTableViewobjet. Il présente à l'utilisateur une vue déroulante et modifiable qui peut être placée sur n'importe quelle fenêtre de niveau supérieur.
Un objet QSqlTableModel est déclaré de la manière suivante -
model = QtSql.QSqlTableModel()
Sa stratégie d'édition peut être définie sur l'une des options suivantes:
QSqlTableModel.OnFieldChange | Tous les changements seront appliqués immédiatement |
---|---|
QSqlTableModel.OnRowChange | Les modifications seront appliquées lorsque l'utilisateur sélectionne une ligne différente |
QSqlTableModel.OnManualSubmit | Toutes les modifications seront mises en cache jusqu'à ce que submitAll () ou revertAll () soit appelé |
Exemple
Dans l'exemple suivant, la table des sportifs est utilisée comme modèle et la stratégie est définie comme -
model.setTable('sportsmen')
model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
model.select()
La classe QTableView fait partie du framework Model / View dans PyQt. L'objet QTableView est créé comme suit -
view = QtGui.QTableView()
view.setModel(model)
view.setWindowTitle(title)
return view
Cet objet QTableView et deux widgets QPushButton sont ajoutés à la fenêtre QDialog de niveau supérieur. Le signal cliqué () du bouton d'ajout est connecté à addrow () qui exécute insertRow () sur la table modèle.
button.clicked.connect(addrow)
def addrow():
print model.rowCount()
ret = model.insertRows(model.rowCount(), 1)
print ret
L'emplacement associé au bouton de suppression exécute une fonction lambda qui supprime une ligne, qui est sélectionnée par l'utilisateur.
btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))
Le code complet est le suivant -
import sys
from PyQt5.QtSql import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def initializeModel(model):
model.setTable('sportsmen')
model.setEditStrategy(QSqlTableModel.OnFieldChange)
model.select()
model.setHeaderData(0, Qt.Horizontal, "ID")
model.setHeaderData(1, Qt.Horizontal, "First name")
model.setHeaderData(2, Qt.Horizontal, "Last name")
def createView(title, model):
view = QTableView()
view.setModel(model)
view.setWindowTitle(title)
return view
def addrow():
print (model.rowCount())
ret = model.insertRows(model.rowCount(), 1)
print (ret)
def findrow(i):
delrow = i.row()
if __name__ == '__main__':
app = QApplication(sys.argv)
db = QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sportsdatabase.db')
model = QSqlTableModel()
delrow = -1
initializeModel(model)
view1 = createView("Table Model (View 1)", model)
view1.clicked.connect(findrow)
dlg = QDialog()
layout = QVBoxLayout()
layout.addWidget(view1)
button = QPushButton("Add a row")
button.clicked.connect(addrow)
layout.addWidget(button)
btn1 = QPushButton("del a row")
btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))
layout.addWidget(btn1)
dlg.setLayout(layout)
dlg.setWindowTitle("Database Demo")
dlg.show()
sys.exit(app.exec_())
Le code ci-dessus produit la sortie suivante -
Essayez d'ajouter et de supprimer quelques enregistrements et revenez à SQLiteStudio pour confirmer les transactions.