1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
#!/bin/env python
############################################################################
##
## Copyright (C) 2004-2005 Trolltech AS. All rights reserved.
##
## This file is part of the example classes of the Qt Toolkit.
##
## This file may be used under the terms of the GNU General Public
## License version 2.0 as published by the Free Software Foundation
## and appearing in the file LICENSE.GPL included in the packaging of
## this file. Please review the following information to ensure GNU
## General Public Licensing requirements will be met:
## http://www.trolltech.com/products/qt/opensource.html
##
## If you are unsure which license is appropriate for your use, please
## review the following information:
## http://www.trolltech.com/products/qt/licensing.html or contact the
## sales department at sales@trolltech.com.
##
## This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
## WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
##
############################################################################
import sys
from PyQt4 import QtCore, QtGui, QtSql
import connection
class TableEditor(QtGui.QDialog):
def __init__(self, tableName, parent = None):
QtGui.QDialog.__init__(self, parent)
self.model = QtSql.QSqlTableModel(self)
self.model.setTable(tableName)
self.model.setEditStrategy(QtSql.QSqlTableModel.OnManualSubmit)
self.model.select()
self.model.setHeaderData(0, QtCore.Qt.Horizontal,
QtCore.QVariant(self.tr("ID")))
self.model.setHeaderData(1, QtCore.Qt.Horizontal,
QtCore.QVariant(self.tr("First name")))
self.model.setHeaderData(2, QtCore.Qt.Horizontal,
QtCore.QVariant(self.tr("Last name")))
view = QtGui.QTableView()
view.setModel(self.model)
self.submitButton = QtGui.QPushButton(self.tr("Submit"))
self.submitButton.setDefault(True)
self.revertButton = QtGui.QPushButton(self.tr("&Revert"))
self.quitButton = QtGui.QPushButton(self.tr("Quit"))
self.connect(self.submitButton, QtCore.SIGNAL("clicked()"), self.submit)
self.connect(self.revertButton, QtCore.SIGNAL("clicked()"),
self.model.revertAll)
self.connect(self.quitButton, QtCore.SIGNAL("clicked()"), self.close)
buttonLayout = QtGui.QVBoxLayout()
buttonLayout.addWidget(self.submitButton)
buttonLayout.addWidget(self.revertButton)
buttonLayout.addWidget(self.quitButton)
buttonLayout.addStretch(1)
mainLayout = QtGui.QHBoxLayout()
mainLayout.addWidget(view)
mainLayout.addLayout(buttonLayout)
self.setLayout(mainLayout)
self.setWindowTitle(self.tr("Cached Table"))
def submit(self):
self.model.database().transaction()
if self.model.submitAll():
self.model.database().commit()
else:
self.model.database().rollback()
QtGui.QMessageBox.warning(self, self.tr("Cached Table"),
self.tr("The database reported an error: %1")
.arg(self.model.lastError().text()))
if __name__ == "__main__":
app = QtGui.QApplication(sys.argv)
if not connection.createConnection():
sys.exit(1)
editor = TableEditor("person")
editor.show()
sys.exit(editor.exec_())
|