Ruslan Polupan
31 августа 2016 г. 1:28

Возможно ли использовать trim в столбцах QSqlTableModel ?

QSqlTableModel, trim

Исторически сложилось, что в базе данных есть поля с записями такого вида
"Кравченко________________________________________________________".
Т.е. заполненные пробелами до максимального значения длины поля заданного при создании таблицы.
Стоит вопрос где их убирать.
если бы это была QSqlQueryModel тогда просто убираем пробелы в запросе.
modelListOperators->setQuery("SELECT trim(name) FROM operators",dbc);
А вот как это организовать в QSqlTableModel?

Или я плохо изучал Асистант… :-)

0

Вам это нравится? Поделитесь в социальных сетях!

1
Evgenii Legotckoi
  • 31 августа 2016 г. 14:29
  • Ответ был помечен как решение.

Полагаю, что в QSqlTableModel при изъятии данных из базы данных убрать пробелы сразу не получится.
Но если наследоваться от QSqlTableModel, то можно переопределить метод
QVariant data(const QModelIndex & index, int role = Qt::DisplayRole) const;
И уже в нём убрать пробелы.
Думаю, что должно сработать, если написать следующим образом:

QVariant MySqlTableModel::data(const QModelIndex &index, int role) const
{
    return QSqlTableModel::data(index, role).toString().trimmed();
}

 

    Комментарии

    Только авторизованные пользователи могут публиковать комментарии.
    Пожалуйста, авторизуйтесь или зарегистрируйтесь
    • Последние комментарии
    • IscanderChe
      12 апреля 2025 г. 17:12
      Добрый день. Спасибо Вам за этот проект и отдельно за ответы на форуме, которые мне очень помогли в некоммерческих пет-проектах. Профессиональным программистом я так и не стал, но узнал мно…
    • AK
      1 апреля 2025 г. 11:41
      Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
    • Evgenii Legotckoi
      9 марта 2025 г. 21:02
      К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
    • VP
      9 марта 2025 г. 16:14
      Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
    • ИМ
      22 ноября 2024 г. 21:51
      Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…