PyQt - डेटाबेस हैंडलिंग
PyQt API में कई SQL आधारित डेटाबेस के साथ संचार करने के लिए एक विस्तृत वर्ग प्रणाली है। इसके QSqlDatabase कनेक्शन ऑब्जेक्ट के माध्यम से पहुँच प्रदान करता है। निम्नलिखित वर्तमान में उपलब्ध SQL ड्राइवरों की सूची है -
अनु क्रमांक। | ड्राइवर का प्रकार और विवरण |
---|---|
1 | QDB2 आईबीएम DB2 |
2 | QIBASE बोरलैंड इंटरबेस ड्राइवर |
3 | QMYSQL MySQL ड्राइवर |
4 | QOCI ओरेकल कॉल इंटरफ़ेस ड्राइवर |
5 | QODBC ODBC ड्राइवर (Microsoft SQL सर्वर शामिल है) |
6 | QPSQL PostgreSQL ड्राइवर |
7 | QSQLITE SQLite संस्करण 3 या उससे ऊपर |
8 | QSQLITE2 SQLite संस्करण 2 |
उदाहरण
SQLite डेटाबेस के साथ एक कनेक्शन स्थैतिक विधि का उपयोग करके स्थापित किया गया है -
db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sports.db')
QSqlDatabase class के अन्य तरीके इस प्रकार हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | setDatabaseName() उस डेटाबेस का नाम सेट करता है जिसके साथ कनेक्शन मांगा गया है |
2 | setHostName() उस होस्ट का नाम सेट करता है जिस पर डेटाबेस स्थापित है |
3 | setUserName() कनेक्शन के लिए उपयोगकर्ता नाम निर्दिष्ट करता है |
4 | setPassword() यदि कोई हो तो कनेक्शन ऑब्जेक्ट का पासवर्ड सेट करता है |
5 | commit() लेनदेन को पूरा करता है और सफल होने पर सही रिटर्न देता है |
6 | rollback() डेटाबेस लेनदेन को वापस रोल करता है |
7 | close() कनेक्शन बंद कर देता है |
QSqlQuery वर्ग में SQL कमांड को निष्पादित और हेरफेर करने की कार्यक्षमता है। डीडीएल और डीएमएल दोनों प्रकार के एसक्यूएल प्रश्नों को निष्पादित किया जा सकता है। कक्षा में सबसे महत्वपूर्ण तरीका है exec_ (), जो एक तर्क के रूप में लेता है जिसमें SQL स्टेटमेंट को निष्पादित किया जाता है।
query = QtSql.QSqlQuery()
query.exec_("create table sportsmen(id int primary key,
" "firstname varchar(20), lastname varchar(20))")
निम्न स्क्रिप्ट पाँच रिकॉर्ड के साथ आबादी वाले स्पोर्ट्सपर्सन की तालिका के साथ SQLite डेटाबेस sports.db बनाता है।
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()
PyQt में QSqlTableModel क्लास एक उच्च-स्तरीय इंटरफ़ेस है जो एकल तालिका में रिकॉर्ड पढ़ने और लिखने के लिए संपादन योग्य डेटा मॉडल प्रदान करता है। यह मॉडल किसी क्यूटेबल व्यू ऑब्जेक्ट को पॉप्युलेट करने के लिए उपयोग किया जाता है। यह उपयोगकर्ता को एक स्क्रॉल करने योग्य और संपादन योग्य दृश्य प्रस्तुत करता है जिसे किसी भी शीर्ष स्तर की खिड़की पर रखा जा सकता है।
एक qableableModel वस्तु को निम्नलिखित तरीके से घोषित किया जाता है -
model = QtSql.QSqlTableModel()
इसकी संपादन रणनीति निम्नलिखित में से किसी में भी सेट की जा सकती है -
QSqlTableModel.OnFieldChange | सभी परिवर्तनों को तुरंत लागू किया जाएगा |
QSqlTableModel.OnRowChange | जब उपयोगकर्ता एक अलग पंक्ति का चयन करता है तो परिवर्तन लागू किए जाएंगे |
QSqlTableModel.OnManualSubmit | सभी परिवर्तनों को तब तक कैश किया जाएगा जब तक कि सब सबमिट नहीं करेंगे () या रिवर्ट () को कहा जाता है |
उदाहरण
निम्नलिखित उदाहरण में, स्पोर्ट्सपर्सन टेबल का उपयोग एक मॉडल के रूप में किया जाता है और रणनीति निम्नानुसार सेट की जाती है -
model.setTable('sportsmen')
model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
model.select()
क्यूटेबल व्यू वर्ग PyQt में मॉडल / व्यू फ्रेमवर्क का हिस्सा है। QTableView ऑब्जेक्ट निम्नानुसार बनाया गया है -
view = QtGui.QTableView()
view.setModel(model)
view.setWindowTitle(title)
return view
यह qableableView ऑब्जेक्ट और दो QPushButton विजेट्स शीर्ष स्तर QDialog विंडो में जोड़े जाते हैं। ऐड बटन पर क्लिक () सिग्नल एड्रो से जुड़ा हुआ है () जो मॉडल टेबल पर इन्सर्ट रो () करता है।
button.clicked.connect(addrow)
def addrow():
print model.rowCount()
ret = model.insertRows(model.rowCount(), 1)
print ret
डिलीट बटन से जुड़ा स्लॉट एक लैंबडा फ़ंक्शन को निष्पादित करता है जो एक पंक्ति को हटाता है, जिसे उपयोगकर्ता द्वारा चुना जाता है।
btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))
पूरा कोड इस प्रकार है -
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_())
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -