Ruslan PolupanMay 29, 2020, 2:20 a.m.

QTablwView + QSqlQueryModel скрыть пустой столбец

QSqlQueryModel, QTableView, hidecolumn

Доброго времени суток.
Собственно сабж.
При выполении запроса для создания модели иногода получается что данных по этому полю в базе данных нет. Хотелось бы его не отображать в представлении.
Есть ли возможность в таком случае определить что столбец пуст каким то другим способом кроме перебора значений модели?

Спасибо.

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
4

Добрый день.
Думаю, что какой-нибудь SQL запрос, который посчитает количество строк, где значения не равны NULL или существуют значения, отличные от пустой строки или чего-то типо этого.
И делать его перед выборкой данных в таблице.

IP

Я использую так

ui->tablwView->horizontalHeader()->hideSection(0);
ui->tablwView->horizontalHeader()->hideSection(1);

где tablwView - объект класса QTablwView, в данном примере скрываются первые два столбца. При этом доступ к данным в столбцах можно получить так

const int currentId = m_model->index(currRow, 0).data().toInt();

где currRow - нужная строка таблицы, m_model - наследник QAbstractTableModel

Если столбец пуст (нет данных), то тут проще SQL запрос исправить

Вы описали как раз то, что топикстартер не хочет использовать.
Вы в данном случае будете перебирать все строки, чтобы выяснить есть ли значения, или нет, по всем строкам в интересующем столбце.

Нужно перед выборкой из базы данных предварительно написать запрос, который будет иметь дополнительное условие фильтрации, который позволит проверить весь столбец на пустые значения и вернёт количество строк. Если строк будет 0, значит можно скрыть колонку.

IP

Да, понятно.
В данном случае лучше использовать серверную процедуру (если такие поддерживаются), в которой будет проверяться наличие всех пустых строк у нужного столбца и вызываться соответствующий запрос (внутри серверной процедуры)

Comments

Only authorized users can post comments.
Please, Log in or Sign up
How to become an author?

Contribute to the evolution of the EVILEG community.

Learn how to become a site author.

Learn it
Donate

Good day, Dear Users!!!

I am Evgenii Legotckoi, developer of EVILEG. And it is my hobby project, which helps to learn programming another programmers and developers

If the site helped you, and you want also support the development of the site, than you can donate by following ways

PayPalYandex.Money
Timeweb

Let me recommend you the excellent hosting on which EVILEG is located.

For many years, Timeweb has been proving his stability.

For projects on Django I recommend VDS hosting

View Hosting
R

C++ - Test 002. Constants

  • Result:75points,
  • Rating points2
R

C++ - Test 001. The first program and data types

  • Result:73points,
  • Rating points1
MS

C++ - Test 005. Structures and Classes

  • Result:75points,
  • Rating points2
Last comments
V

Django - Tutorial 027. Implementation Google reCAPTCHA

Спасибо. Только использую декоратор не в urls.py а перед views
R

Qt WinAPI - Lesson 001. How to collect all DLL, which used in Qt project?

Вы меня не совсем правильно поняли, но все равно спасибо, принял все к сведению. Все сделал как вы сказали, все отлично работает, еще раз огромнейшее спасибо) Разве что только что были опять про…

Qt WinAPI - Lesson 001. How to collect all DLL, which used in Qt project?

Стоило перед использованием что ли инструкцию прочитать https://www.cyberforum.ru/blogs/131347/blog2457.html "После сборки при запуске требовались dll," Ясное дело стоило задепло…
R
R

Qt WinAPI - Lesson 001. How to collect all DLL, which used in Qt project?

Да, собралось. После сборки при запуске требовались dll, перекинул всю папки bin, plugins(не знаю как можно было сделать более умно). Как я понял в первой строке путь к екзешнику вставляю, втор…
Now discuss on the forum
A

Как в Qt в qmenu добавить scrollarea

Добрый день. Мое имя Кристина. Познакомлюсь с другом для встречи. Приеду к тебе в гости или встримся у меня. Живу близко. Мой адрес

Qt C++ и Python

Красиво/некрасиво - это скорее моё личное отношение. Если есть возможность ограничить количество интсрументов, то лучше ограничить. Но не зацикливайтесь на этом. Если у вас есть скрипты Py…

Qt + OpenGL glDeleteVertexArrays

Я не уверен, поскольку с OpenGL очень мало работал. Но может быть OpenGL контекст виджета нужно переинициализовывать. И ещё виджет стоит удалять через метод deleteLater() а не п…

QWebEngineView не запускается если к ПК подключено несколько мониторов

Ну я имел ввиду посмотреть на другом ПК с другой графикой и парой мониторов. Как моей программе назначить использовать определенный граф. адаптер? Вот тут понятия не имею.

Счечик производительности сети

Хорошо. После работы сегодня гляну ваш код внимательно.
About
Services
© EVILEG 2015-2020
Recommend hosting TIMEWEB