PyQt - Penanganan Database

PyQt API berisi sistem kelas yang rumit untuk berkomunikasi dengan banyak database berbasis SQL. QSqlDatabase-nya menyediakan akses melalui objek Connection. Berikut adalah daftar driver SQL yang tersedia saat ini -

Sr.No. Jenis & Deskripsi Driver
1

QDB2

IBM DB2

2

QIBASE

Pengemudi Borland InterBase

3

QMYSQL

Driver MySQL

4

QOCI

Driver Antarmuka Panggilan Oracle

5

QODBC

Driver ODBC (termasuk Microsoft SQL Server)

6

QPSQL

Driver PostgreSQL

7

QSQLITE

SQLite versi 3 atau lebih tinggi

8

QSQLITE2

SQLite versi 2

Contoh

Koneksi dengan database SQLite dibuat menggunakan metode statis -

db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sports.db')

Metode lain dari kelas QSqlDatabase adalah sebagai berikut -

Sr.No. Metode & Deskripsi
1

setDatabaseName()

Menetapkan nama database yang dicari koneksi

2

setHostName()

Menetapkan nama host tempat database diinstal

3

setUserName()

Menentukan nama pengguna untuk koneksi

4

setPassword()

Setel kata sandi objek koneksi jika ada

5

commit()

Melakukan transaksi dan mengembalikan nilai true jika berhasil

6

rollback()

Mengembalikan transaksi database

7

close()

Tutup koneksi

Kelas QSqlQuery memiliki fungsionalitas untuk menjalankan dan memanipulasi perintah SQL. Baik jenis kueri SQL DDL dan DML dapat dijalankan. Metode yang paling penting di kelas adalah exec_ (), yang menganggap string berisi pernyataan SQL untuk dieksekusi sebagai argumen.

query = QtSql.QSqlQuery()
query.exec_("create table sportsmen(id int primary key, 
   " "firstname varchar(20), lastname varchar(20))")

Skrip berikut membuat database SQLite sports.db dengan tabel olahragawan yang diisi dengan lima rekaman.

from PyQt4 import QtSql, QtGui

def createDB():
   db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
   db.setDatabaseName('sports.db')
	
   if not db.open():
      QtGui.QMessageBox.critical(None, QtGui.qApp.tr("Cannot open database"),
         QtGui.qApp.tr("Unable to establish a database connection.\n"
            "This example needs SQLite support. Please read "
            "the Qt SQL driver documentation for information "
            "how to build it.\n\n" "Click Cancel to exit."),
         QtGui.QMessageBox.Cancel)
			
      return False
		
   query = QtSql.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__':
   import sys
	
   app = QtGui.QApplication(sys.argv)
   createDB()

Kelas QSqlTableModel di PyQt adalah antarmuka tingkat tinggi yang menyediakan model data yang dapat diedit untuk membaca dan menulis catatan dalam satu tabel. Model ini digunakan untuk mengisi objek QTableView. Ini menyajikan kepada pengguna tampilan yang dapat digulir dan diedit yang dapat diletakkan di jendela tingkat atas mana pun.

Objek QTableModel dideklarasikan dengan cara berikut -

model = QtSql.QSqlTableModel()

Strategi pengeditannya dapat diatur ke salah satu dari berikut ini -

QSqlTableModel.OnFieldChange Semua perubahan akan segera diterapkan
QSqlTableModel.OnRowChange Perubahan akan diterapkan saat pengguna memilih baris yang berbeda
QSqlTableModel.OnManualSubmit Semua perubahan akan di-cache sampai submitAll () atau revertAll () dipanggil

Contoh

Dalam contoh berikut, tabel olahragawan digunakan sebagai model dan strategi ditetapkan sebagai -

model.setTable('sportsmen') 
model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)

   model.select()

Kelas QTableView adalah bagian dari kerangka Model / View di PyQt. Objek QTableView dibuat sebagai berikut -

view = QtGui.QTableView()
view.setModel(model)
view.setWindowTitle(title)
return view

Objek QTableView dan dua widget QPushButton ini ditambahkan ke jendela QDialog tingkat atas. Sinyal clicked () dari tombol add terhubung ke addrow () yang melakukan insertRow () pada tabel model.

button.clicked.connect(addrow)
def addrow():
   print model.rowCount()
   ret = model.insertRows(model.rowCount(), 1)
   print ret

Slot yang terkait dengan tombol hapus menjalankan fungsi lambda yang menghapus baris, yang dipilih oleh pengguna.

btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))

Kode lengkapnya adalah sebagai berikut -

import sys
from PyQt4 import QtCore, QtGui, QtSql
import sportsconnection

def initializeModel(model):
   model.setTable('sportsmen')
   model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
   model.select()
   model.setHeaderData(0, QtCore.Qt.Horizontal, "ID")
   model.setHeaderData(1, QtCore.Qt.Horizontal, "First name")
   model.setHeaderData(2, QtCore.Qt.Horizontal, "Last name")
	
def createView(title, model):
   view = QtGui.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 = QtGui.QApplication(sys.argv)
   db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
   db.setDatabaseName('sports.db')
   model = QtSql.QSqlTableModel()
   delrow = -1
   initializeModel(model)
	
   view1 = createView("Table Model (View 1)", model)
   view1.clicked.connect(findrow)
	
   dlg = QtGui.QDialog()
   layout = QtGui.QVBoxLayout()
   layout.addWidget(view1)
	
   button = QtGui.QPushButton("Add a row")
   button.clicked.connect(addrow)
   layout.addWidget(button)
	
   btn1 = QtGui.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_())

Kode di atas menghasilkan keluaran sebagai berikut -