Уведомления

Группа в Telegram: @pythonsu
  • Начало
  • » GUI
  • » Не работает функция удаление строки в QSqlQueryModel. [RSS Feed]

#1 Июнь 13, 2020 20:04:57

troyann
Зарегистрирован: 2020-06-13
Сообщения: 1
Репутация: +  0  -
Профиль   Отправить e-mail  

Не работает функция удаление строки в QSqlQueryModel.

Здравствуйте. Пишу свою модель которая наследуется от QSqlQueryModel т.к. необходимо организовать удаление строки из базы данных. Но сама функция удаления либо не удаляет выбранную строку, либо удаляет но всегда последнюю. Подскажите где в ней ошибка.

 class NewSqlModel(QSqlQueryModel):
    def __init__(self, parent=None):
        super(NewSqlModel, self).__init__()
    def flags(self, index):
        """Предопределим флаги для дальнейшего их редактирования в
            модели"""
        f1 = QSqlQueryModel.flags(self, index)
        if index.column() == 0:
            f1 |= Qt.ItemIsEditable
        return f1
    def setData(self, index, value, role=Qt.EditRole):
        """Метод для обновления данных"""
        self.data = QSqlQueryModel.data(self, index, role)
        if index.isValid():
            self.data(index.row(), value)
            self.dataChanged.emit(index, index, role)
            return True
        return False
    # Функция с ошибкой
    def removeRows(self, position, index, parent=QModelIndex()):
        """Производим удаление выбранной строки"""
        self.beginRemoveRows(parent, position, position + index - 1)
        self.query = QSqlQuery('DELETE FROM calculation WHERE id = %d' % position)
        self.endRemoveRows()
        return True
Так же прилагаю функцию подключение модели и вызов функции удаления выбранной строки.
 def connect_column_calc(self):
      """Подключаем модель к БД и производим запрос к ней"""
      self.calculation_model = NewSqlModel()
      self.calculation_model.setQuery('SELECT id, number_invoice, inv_date, company_name, '
                                      '(all_sum / 100.0) AS all_sum, signatory FROM calculation')
    def del_pushbutton(self):
        """Функция удаляет выделенную строку из БД.
               Запускается через кнопку"""
        if self.inv_tabView.selectionModel().hasSelection():
            for index in self.inv_tabView.selectedIndexes() or []:
                print('Удаляется строка %d...' % index.row())
                self.start_menu.model().removeRows(index.row(), index.row())
        else:
            QMessageBox.warning(None, 'Ошибка удаления', 'Строки для удаления отсутствуют! \n'
                                                         'Выделите строку и повторите удаление.')

Офлайн

  • Начало
  • » GUI
  • » Не работает функция удаление строки в QSqlQueryModel.[RSS Feed]

Board footer

Модераторировать

Powered by DjangoBB

Lo-Fi Version