Ruslan Polupan
Aug. 31, 2016, 1:28 a.m.

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

QSqlTableModel, trim

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

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

0

Do you like it? Share on social networks!

1
Evgenii Legotckoi
  • Aug. 31, 2016, 2:29 p.m.
  • The answer was marked as a solution.

Полагаю, что в 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();
}

 

    Comments

    Only authorized users can post comments.
    Please, Log in or Sign up
    • Last comments
    • AK
      April 1, 2025, 11:41 a.m.
      Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
    • Evgenii Legotckoi
      March 9, 2025, 9:02 p.m.
      К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
    • VP
      March 9, 2025, 4:14 p.m.
      Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
    • ИМ
      Nov. 22, 2024, 9:51 p.m.
      Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
    • Evgenii Legotckoi
      Oct. 31, 2024, 11:37 p.m.
      Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup